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

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.xdnf.cn/news/6918.html

相关文章:

  • [已解决] LaTeX “Unicode character“ 报错 (中文字符处理)
  • MySQL高可用架构
  • 深入解析Spring Boot与Spring Security的集成实践
  • 游戏详情制作(Navigation组件)
  • 语音合成终身免费畅用![特殊字符] 紧急提醒:禁用更新锁死权限!
  • 电脑桌面便签软件哪个好用?好用便签Windows版下载推荐
  • 大麦(Hordeum vulgare)中 BAHD 超家族酰基转移酶-文献精读129
  • 关于Android Studio for Platform的使用记录
  • 2025最新的软件测试面试大全(含答案+文档)
  • 系统架构设计(十):结构化编程
  • Linux线程同步信号量
  • hbuilderX 安装Prettier格式化代码
  • 哈希的原理、实现
  • 如何通过交流沟通实现闭环思考模式不断实现自身强效赋能-250517
  • 解决“没有找到有效的sudoers资源,退出”
  • 系分论文《论系统需求分析方法及应用》
  • 【通用智能体】Search Tools:Open Deep Research 项目实战指南
  • Python的re模块:正则表达式处理的魔法棒
  • DeepSeek源码深度解析 × 华为仓颉语言编程精粹——从MoE架构到全场景开发生态
  • 单细胞转录组(1)
  • 【51】快速获取数码管段选表(含小数点)及字母表的工具(分享)
  • 局部放大maya的视图HUD文字大小的方法
  • 五、xlib绘制按钮控件
  • DeepSeek-R1 Supervised finetuning and reinforcement learning (SFT + RL)
  • 怎么在excel单元格1-5行中在原来内容前面加上固定一个字?
  • NVMe简介6之PCIe事务层
  • HTTP与HTTPS协议的核心区别
  • Linux调试生成核心存储文件
  • React Hooks 必须在组件最顶层调用的原因解析
  • Linux517 rsync同步 rsync借xinetd托管 配置yum源回顾