指针-数组

1、&数组名

假设int arr [ ] ={1,2,3,4,5}

  1. arr数组名就表示数组的首元素地址
  2. &arr[0] 也表示数组的首元素地址
  3. 但是&arr 表示取得是整个数组的地址

比如

如果说arr是数组的首元素地址,那arr在x86平台下的大小就是4个字节,为什么sizeof(arr)=40?

because 这是一种特俗情况:

  1. sizeof(数组名) 取得是整个数组的地址
  2. &数组名也是整个数组的地址

我们对指针进行+1操作,发现arr和arr[0],+1都是地址都是+4,那就证明它们都是整型指针,+1跳过一个整型,但是&arr + 1 跳过的是40个字节,A8+28=D0,差0X28换10进制也就是跳了40个字节,那就是证明了&arr 取得是整个数组的地址。

2、指针访问数组

既然我们知道arr就是数组的首元素地址,数组的地址又是一块连续的内存空间,所以用int * p

p + i == 数组下标为i的元素的那块空间

又因为p = arr,所以

那也可以写成这种形式,它们是完全相等的;

我们正常写代码的话,这里应该写的是arr[i],但是在编译器里它的形式就是这样的*(arr+i)。

arr[i] -- *(arr+i) -- *(p+i) 它们是一回事情。

还有一种写法,比较特别。

*(arr+i)是支持交换律的,

*(i+arr) == *(arr+i)

*(arr+i) == arr[i]

*(i+arr) == i[arr]

结果都是一样的,这是写法不一样。

3、一维数组传参

我们把数组传参,传的是什么?

我们传的其实是地址,不难看出来,在主函数里面我们求的元素个数是10,但是在test函数里面求得是1。

在test函数里面,我们已经知道sz2得结果是1,我们反推,sizeof(arr[0])肯定是4,那什么/4等于1,那肯定也是4,如果我们数组传参传得是数组,那应该就是数组的大小40/4=10,所以数组传参传的是地址。

既然传的是地址,就不用创建一块数组,也就不用写数组元素的个数了,比如int arr[10],那最好用指针的形式来接收,那就用int * p 来接收。

那为什么我们还要写成这种形式 int arr[ ] 呢?

为了可读性,给我传数组,那我就要数组的形式来接收,这是为了方便理解。

4、冒泡排序

冒泡排序的思想就是两两相邻的元素互相比较

假设我们排的是升序

第一个我们要解决是躺数的问题,排序一个元素需要一趟,假设这里10个元素,就需要10-1躺,因为排到最后第二个元素的时候就不用排了,最后一个就已经排好了,假设有n个元素,那就需要n-1躺。

第二个问题就是内部细节的问题,就是两个元素相比较,我们比的是升序,降序就反过来,假设arr[j]>arr[j+1],前面的元素大于后面的元素就交换;那交换的过程中,第一趟交换9对,第二天交换8对。。。。以此类推,每一个都在变化,这是我们可以sz-1-i

5、二级指针

  1. 二级指针就是存放 一级指针变量的地址 的指针;
  2. 存放地址的指针变量也是变量,内存也会给它内存空间;
  3. 假设是ppn; 存放的就是pn的地址;
  4. ppn的类型,*ppn表示是指针变量,int*表示它指向的对象是int*的指针;

6、指针数组

  1. 指针数组就是存放指针的数组
  2. 每个元素就是指针
  3. 数组每个元素的类型是int*
  4. 通过元素下标访问地址,再解引用

7、指针二维数组

  1. 指针二维数组就是把多个一维数组的地址存起来
  2. 通过下标访问,得到每一行的数组名
  3. 再通过列下标访问每一列的元素
相关推荐
LuminousCPP2 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
kkeeper~26 分钟前
0基础C语言积跬步之内存函数
c语言·开发语言
Chen_harmony29 分钟前
【习题04】计算求和
c语言
我不是懒洋洋2 小时前
大语言模型(LLM)入门:从Transformer到ChatGPT
c语言·开发语言·c++
『昊纸』℃2 小时前
一篇读懂C语言
c语言·编程语言·嵌入式系统·系统编程·历史发展
akarinnnn3 小时前
深入理解内存函数:原理、应用与优化
c语言·网络·数据结构·算法
代码中介商3 小时前
排序算法完全指南(三):插入排序深度详解
算法·排序算法
承渊政道3 小时前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法
宠..3 小时前
VS Code SSH 远程连接 Ubuntu 并实现快速运行(C/C++示例)
java·运维·c语言·开发语言·c++·ubuntu·ssh
WL_Aurora3 小时前
Python 算法基础篇之排序算法(二):希尔、快速、归并
python·算法·排序算法