当前位置: 首页 > article >正文

C43-指针与数组

一 定义一个指针变量指向数组

1.途径一:指向数组首元素的地址

  • 代码示例:
#include <stdio.h>
int main()
{int arr[3]={2,4,5};int *p;p=&arr[0];printf("该数组的首元素是:%d",*p);return 0;
}
  • 成果展示:

image-20250517140519864

  • 报错与总结:
    • 给指针变量赋值时,未在数组首元素前输入取地址符image-20250517140446723

2.途径二:数组名代表数组首元素的地址,因此可直接指向数组名

  • 代码示例:
#include <stdio.h>
int main()
{int arr[3]={55,4,5};int *p;p=arr;printf("该数组的首元素是:%d",*p);return 0;
}
  • 成果展示:

image-20250517140923065

  • 报错与总结:无

二 指针偏移遍历数组

  • 代码示例:
#include <stdio.h>
int main()
{int arr[3]={2,4,5};int *p;p=&arr[0];int len;len=sizeof(arr)/sizeof(arr[0]);int i;for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*(p+i));}return 0;
}
  • 成果展示:

image-20250517142330244

  • 报错与总结:无

  • 指针遍历数组与下标遍历数组的优缺点

    • 指针:
      • 优:访问效率更高,占用系统资源更少
      • 缺:相较于下标法,程序可读性较弱
    • 下标:
      • 优:可读性强,更容易理解
      • 缺:占用系统资源更大

三 指针偏移的补充

若是采用指针自加偏移,第二次以上遍历数组时,指针变量记得回到首地址,否则会越界

  • 没有回到首地址:

    • 代码示例:
    #include <stdio.h>
    int main()
    {int arr[3]={2,4,5};int *p;p=&arr[0];int len;len=sizeof(arr)/sizeof(arr[0]);int i;puts("第一次遍历:");for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*p++);}puts("\n第二次遍历:");for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*p++);}return 0;
    }
    • 成果展示:

    image-20250517145409662

    • 报错与总结:无
  • 回到首地址:

    • 代码示例:
    #include <stdio.h>
    int main()
    {int arr[3]={2,4,5};int *p;p=&arr[0];int len;len=sizeof(arr)/sizeof(arr[0]);int i;puts("第一次遍历:");for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*p++);}p=&arr[0];  //我们在这里让指针变量回到首地址puts("\n第二次遍历:");for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*p++);}return 0;
    }
    • 成果展示:

    image-20250517145638172

    • 报错与总结:无

四 指针与数组名见怪不怪的用法

  1. 指针当做数组名,下标法访问
  • 代码示例:
#include <stdio.h>
int main()
{int arr[3]={26,43,67};int *p;p=arr;int len;len=sizeof(arr)/sizeof(arr[0]);int i;for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,p[i]);}return 0;
}
  • 成果展示:

image-20250517150505921

  • 报错与总结:忘记给指针变量赋值,导致出现随机值

2.数组名拿来加:数组名当做指针用,但要注意数组名是一个常量指针,不可自加

  • 代码示例:
#include <stdio.h>
int main()
{int arr[3]={26,43,67};int len;len=sizeof(arr)/sizeof(arr[0]);int i;for(i=0;i<len;i++){printf("第%d个元素是:%d\n",i+1,*(arr+i));	//注意:不可以:*arr++}return 0;
}
  • 成果展示:

image-20250517151316183

  • 报错与总结:无
http://www.lryc.cn/news/2378536.html

相关文章:

  • UDP--DDR--SFP,FPGA实现之ddr读写控制模块
  • 云计算与大数据进阶 | 26、解锁云架构核心:深度解析可扩展数据库的5大策略与挑战(上)
  • AI Agent | Coze 插件使用指南:从功能解析到实操步骤
  • 06、基础入门-SpringBoot-依赖管理特性
  • MK米客方德SD NAND:无人机存储的高效解决方案
  • 【vscode】解决vscode无法安装远程服务器插件问题,显示正在安装
  • 1688 数据接口调用秘籍:高效获取商品实时信息的开发指南
  • 【Spring】Spring的请求处理
  • 粒子群算法(PSO算法)
  • git提交库常用词
  • LLM智能体新纪元:深入解析MCP与A2A协议,赋能智能自动化协作
  • SAP学习笔记 - 开发豆知识01 - CDS SDK命令出乱码 (cds init CAP-Test03 --add java)
  • (C语言)超市管理系统 (正式版)(指针)(数据结构)(清屏操作)(文件读写)(网页版预告)(html)(js)(json)
  • 进阶-数据结构部分:​​​​​​​2、常用排序算法
  • 解决 Three.js Raycaster 点击位置与实际交点偏差问题
  • 25、DeepSeek-R1论文笔记
  • LeetCode --- 156双周赛
  • 模型量化AWQ和GPTQ哪种效果好?
  • npm 报错 gyp verb `which` failed Error: not found: python2 解决方案
  • 初识Linux · IP协议· 下
  • 5.27本日总结
  • JavaScript基础-创建对象的三种方式
  • JAVA的常见API文档(上)
  • JavaScript 中的 for...in 和 for...of 循环详解
  • AtCoder AT_abc406_c [ABC406C] ~
  • Spark,连接MySQL数据库,添加数据,读取数据
  • Linux容器技术详解
  • 【EDA软件】【联合Modelsim仿真使用方法】
  • STM32 __main
  • 【离散化 线段树】P3740 [HAOI2014] 贴海报|普及+