C语言—指针(3)
嘿嘿嘿嘿,你看我像指针吗?
不会写,等我啥时候会写了再说吧,真的累了,倦了
1.面试题
1)定义整形变量i;
2)p为指向整形变量的指针变量;
3)定义整形一维数组p,它有n 个整形元素;
4)定义一维指针数组p,它有n个指向整形变量的指针元素;
5)定义p为指向(含有n个整形元素的一维数组)的指针变量;
6)p为返回整形函数值的函数;
7)p为返回一个指针的函数,该指针指向整形数据;
8)p为指向函数的指针变量,该函数返回一个整形值;
9)p是一个指向整形指针变量的指针变量;
嘿嘿我猜是这样的,没时间了就这样凑合吧,我写给自己看的
#include <stdio.h>int main() {int i; // 1.定义整形变量iint *p; // 2.p为指向整形变量的指针变量int arr[n]; // 3.定义整形一维数组p,它有n个整形元素// 注意:C99及以后标准才支持变量长度数组,或者在定义数组时已知n的具体值int *p[n]; // 4.定义一维指针数组p,它有n个指向整形变量的指针元素int (*p)[n]; // 5.定义p为指向(含有n个整形元素的一维数组)的指针变量int p(); // 6.p为返回整形函数值的函数int *p(); // 7.p为返回一个指针的函数,该指针指向整形数据int (*p)(); // 8.p为指向函数的指针变量,该函数返回一个整形值int **p; // 9.p是一个指向整形指针变量的指针变量return 0;
}

2.动态申请一个具有10个float类型元素的内存空间,从一个已有的数组中拷贝数据,并找出第一次出现 12.35 的下标位置,并输出。

/*2.动态申请一个具有10个float类型元素的内存空间,从一个已有的数组中拷贝数据并找出第一次出现 12.35 的下标位置,并输出.*/#include <stdio.h>
#include <stdlib.h>int main() {float existingArray[] = {1.1, 2.2, 3.3, 4.4, 5.5, 12.35, 7.7, 8.8, 9.9, 10.1};float *dynamicArray = NULL;// 动态申请内存dynamicArray = (float *)malloc(10 * sizeof(float));if (!dynamicArray){puts("malloc failed!");return -1;}// 从已有的数组中拷贝数据for (int i = 0; i < 10; i++){dynamicArray[i] = existingArray[i];}// 查找第一次出现12.35的位置int index = -1;for (int i = 0; i < 10; i++){if (dynamicArray[i] == (float)12.35){index = i;break;}}if(index != -1){printf("第一次出现12.35的位置是: %d\n",index);}else{printf("未在数组中找到12.35\n");}// 释放内存free(dynamicArray);return 0;
}
3.动态申请一个整型数组,并给每个元素赋值,要求删除第3个元素;

/*3.动态申请一个整型数组,并给每个元素赋值,要求删除第3个元素;*/#include <stdio.h>
#include <stdlib.h>int main()
{// 动态申请一个能存储5个整型数据的数组int *array = (int*)malloc(5 * sizeof(int));if (!array){puts("malloc failed!");return -1;}// 给数组的每个元素赋值for (int i = 0; i < 5; i++){array[i] = i + 1;}printf("原始数组:");for(int i = 0;i < 5;i++){printf("%3d",array[i]);}printf("\n");// 删除第3个元素(在C中数组索引从0开始)// 将第3个元素之后的所有元素向前移动一个位置for (int i = 2; i < 4; i++){array[i] = array[i + 1];}// 释放被移动过的元素原来的位置的内存//free(array + 2);printf("修改后的数组:");for(int i = 0;i < 4;i++){printf("%3d",array[i]);}printf("\n");// 释放数组其余部分的内存free(array);return 0;
}
4.动态申请一个整型数组,并给每个元素赋值,要求在第4个元素后插入100;

/*4.动态申请一个整型数组,并给每个元素赋值,要求在第4个元素后插入100;*/#include <stdio.h>
#include <stdlib.h>int main()
{// 动态申请一个能存储5个整型数据的数组int *array = (int*)malloc(5 * sizeof(int));if (!array){puts("malloc failed");return -1;}// 给数组的每个元素赋值并打印printf("原始数组是:");for (int i = 0; i < 5; i++){array[i] = i + 1;printf("%d",array[i]);}printf("\n");// 在第4个元素后插入100// 注意:在C中数组索引从0开始,所以第4个元素是索引为3的元素int *insert_pos = array + 3;*insert_pos = 100;// 打印数组printf("改变之后的数组:");for (int i = 0; i < 5; i++){printf("%d ", array[i]);}printf("\n");// 释放数组内存free(array);return 0;
}
思考题:
编写一个函数,实现 void *memmove(void *dest, const void *src, size_t n);的功能。
提示: 将形参dest,src 先强制类型转换为一个char* 类型,然后利用从后向前逐字节进行数据拷贝,最终返回dest 指针

#include <stdio.h>
#include <stdlib.h>void* mymemmove(void *dest,const void* src,size_t n)
{char *d = (char*)dest; //强制类型转换char *s = (char*)src;// 如果源地址在目标地址之前,并且源地址和目标地址之间的距离大于要复制的字节数if((s < d) && ((s + n) > d)){//从后往前复制,避免覆盖未复制的数据d += n - 1; //因为int是4个字节,在第四个元素插入的话是移动3个s += n - 1;while(n--){// *d-- = *s--; //使代码更简洁*d = *s;d--;s--;}}else{// 如果源地址在目标地址之后,或者源地址和目标地址之间的距离小于或等于要复制的字节数while(n--){*d = *s;d++;s++; }}return dest; // 返回指向目标地址的指针
}int main(int argc,char** argv)
{int a[6] = {1,7,3,8,2};mymemmove(a+3,a+2,4*sizeof(int)); //调用mymemmove函数,将a+2到a+5的元素移动到a+3的位置a[2] = 100;for(register int i = 0; i < 6; i++)printf("%5d",a[i]);printf("\n");return 0;
}
相关文章:
C语言—指针(3)
嘿嘿嘿嘿,你看我像指针吗? 不会写,等我啥时候会写了再说吧,真的累了,倦了 1.面试题 1)定义整形变量i; 2)p为指向整形变量的指针变量; 3)定…...
【八股文】面向对象基础
【八股文】面向对象基础 面向对象和面向过程的区别 面向过程把解决问题的过程拆成一个个方法,通过一个个方法的执行解决问题。面向对象会先抽象出对象,然后用对象执行方法的方式解决问题。 创建一个对象用什么运算符?对象实体与对象引用有何不同? …...
Day49 647 回文子串 516 最长回文子序列
647 回文子串 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串。 具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被视作不同的子串。 方法一:动态规划: 采用一个二维的dp数组…...
探秘GNU/Linux Shell:命令行的魔法世界
GNU/Linux的Shell是一种特殊的交互式工具,为用户提供了强大的控制和管理Linux系统的方式。在这个博客中,我们将深入了解Shell的基本概念、功能以及不同类型的Shell。 Shell的本质 Shell的核心是命令行提示符,它是用户与Linux系统进行交互的…...
基于STM32F407的coreJSON使用教程
目录 概述 工程建立 代码集成 函数介绍 使用示例 概述 coreJSON是FreeRTOS中的一个组件库,支持key查找的解析器,他只是一个解析器,不能生成json数据。同时严格执行 ECMA-404 JSON 标准。该库用 C 语言编写,设计符合 ISO C90…...
keepalived双主模式测试
文章目录 环境准备部署安装keepavlived配置启动测试模拟Nginx宕机重新启动问题分析 环境准备 测试一下keepalived的双主模式,所谓双主模式就是两个keepavlied节点各持有一个/组虚IP,默认情况下,二者互为主备,同时对外提供服务&am…...
微服务中的熔断、降级和限流
在现代微服务架构中,熔断、降级和限流是保障系统稳定性和可靠性的重要手段。本文将深入探讨这三种机制在微服务架构中的作用、原理以及实践方法。 1. 熔断(Circuit Breaker) 1.1 作用和原理 熔断器是一种可以在服务发生故障时快速中断请求的机制,防止故障蔓延到整个系统…...
2023年便宜的云服务器分享:最低26元4核16G
2024年阿里云服务器租用价格表更新,云服务器ECS经济型e实例2核2G、3M固定带宽99元一年、ECS u1实例2核4G、5M固定带宽、80G ESSD Entry盘优惠价格199元一年,轻量应用服务器2核2G3M带宽轻量服务器一年61元、2核4G4M带宽轻量服务器一年165元12个月、2核4G服…...
汽车零部件制造业MES系统解决方案
一、汽车零部件行业现状 随着全球汽车产业不断升级,汽车零部件市场竞争日趋激烈,从上游的钢铁、塑料、橡胶等生产到下游的主机厂配套制造,均已成为全球各国汽车制造大佬战略目标调整的焦点,其意欲在汽车零部件行业快速开疆扩土&…...
区块链/加密币/敏感/特殊题材专供外媒发稿,英文多国语言海外新闻营销推广
【本篇由言同数字科技有限公司原创】敏感题材是海外媒体在报道过程中常遇到的难题,需要平衡新闻真实性、公正性与敏感性。本文将探讨海外媒体报道敏感题材所面临的挑战,并介绍如何抓住机遇提高报道质量。 第一部分:敏感题材报道的挑战 报道…...
初识Nginx
摘要:最近几个项目中的接口总是访问受限,需要后端同事配置Nginx代理,了解下Nginx后面自己配置。 Nginx 是一款高性能的开源 Web 服务器和反向代理服务器。它具有轻量级、高并发、低内存消耗等特点,常被用作静态资源服务、负载…...
Rust语言之多线程
文章目录 一、简介二、创建线程1.创建一个线程2.创建多个线程生成随机数尝试让程序睡一会儿引入多线程 三、线程返回值的处理1.每个线程处理一个独立的值2.多个线程处理一个值Arc(原子引用计数)Mutex(互斥锁)RwLock(读…...
现有的通用模型中融入少量中文数据没有太大意义少量的数据就能影响整个大模型
相关链接:只修改一个关键参数,就会毁了整个百亿参数大模型? | 新程序员-CSDN博客 现象 1:mBERT 模型的跨语言迁移 现象 2:大语言模型同样存在显著的语言对齐 现象 3:知识与语言分离 现象 4:…...
vscode 开发代码片段插件
环境准备 node - 20v版本 ,推荐使用nvm进行版本控制全局安装 "yo" 是 Yeoman 工具的命令行工具, npm i yo -g全局安装 generator-code 是一个 Yeoman 脚手架 gernerator-code npm i gernerator-code -g全局安装 npm install -g vsce官方文档 …...
算法竞赛STL:array的使用方法
算法竞赛STL:array的使用方法 文章目录 算法竞赛STL:array的使用方法array array 容器描述: array是一种固定大小的容器,它包含指定数量的元素。每个元素都有一个非负整数索引,用于访问或修改它。 使用方法ÿ…...
MyBatis sql拦截器实现一个自动根据租户进行分表的方案
需求描述: 在一个多租户系统中,通过 MyBatis 实现动态数据表分离。具体来说,您希望通过 MyBatis 拦截器在执行 SQL 时自动将表名根据当前租户 ID (tenantId) 进行修改。这样,每个租户的数据就可以存储在专属于它们的表中…...
TiDB in 2023, 一次简单的回顾丨PingCAP 唐刘
2023 年已经过去,TiDB 经过了一年的迭代,又往前进步了一点点,我们非常自豪的看到,TiDB 正在不断地帮助我们的客户成功,包括但不限于: ○ 首个云原生、分布式、全栈国产化银行核心业务系统投产上线丨TiDB …...
debug - 只要在内存中有显示相关的数据, 就会被CE找到
文章目录 debug - 只要在内存中有显示相关的实际数据, 就会被CE找到概述笔记demo实现demo运行效果用CE查找实际数据地址找到自己的调试点 - 方法1找到自己的调试点 - 方法2打补丁备注END debug - 只要在内存中有显示相关的实际数据, 就会被CE找到 概述 自己写了一个demo, 想验…...
Redis 单个与多节点如何实现分布式锁
分布式锁 在许多环境中,分布式锁是非常有用的原语,在这些环境中,不同的进程必须以互斥的方式操作共享资源。在应对并发问题时,Redis 客户端还可以通过加锁的方式,来控制并发写操作对共享数据的修改,从而保…...
频段划分学习射频知识的意义
一、射频电路设计与低频电路设计的不同点 随着频率提高,相应电磁波的波长与变得可与分立电路元件的尺寸相比拟时,电阻、电容和电感这些元件的电响应,将偏离他们的理想频率特性。以 WIFI 2.4G 频段为例,当频率为 2437MHz࿰…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
linux之kylin系统nginx的安装
一、nginx的作用 1.可做高性能的web服务器 直接处理静态资源(HTML/CSS/图片等),响应速度远超传统服务器类似apache支持高并发连接 2.反向代理服务器 隐藏后端服务器IP地址,提高安全性 3.负载均衡服务器 支持多种策略分发流量…...
【Web 进阶篇】优雅的接口设计:统一响应、全局异常处理与参数校验
系列回顾: 在上一篇中,我们成功地为应用集成了数据库,并使用 Spring Data JPA 实现了基本的 CRUD API。我们的应用现在能“记忆”数据了!但是,如果你仔细审视那些 API,会发现它们还很“粗糙”:有…...
CMake 从 GitHub 下载第三方库并使用
有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...
IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)
文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...
【Oracle】分区表
个人主页:Guiat 归属专栏:Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...
Fabric V2.5 通用溯源系统——增加图片上传与下载功能
fabric-trace项目在发布一年后,部署量已突破1000次,为支持更多场景,现新增支持图片信息上链,本文对图片上传、下载功能代码进行梳理,包含智能合约、后端、前端部分。 一、智能合约修改 为了增加图片信息上链溯源,需要对底层数据结构进行修改,在此对智能合约中的农产品数…...
Webpack性能优化:构建速度与体积优化策略
一、构建速度优化 1、升级Webpack和Node.js 优化效果:Webpack 4比Webpack 3构建时间降低60%-98%。原因: V8引擎优化(for of替代forEach、Map/Set替代Object)。默认使用更快的md4哈希算法。AST直接从Loa…...
