C语言-----指针数组 \ 数组指针

一 指针数组

用来存放指针的数组

int arr[10]; //整型数组
char ch[5]; //字符数组
int * arr[6]; //存放整型指针的数组
char * arr[5]; //存放字符指针的数组
cpp 复制代码
// 指针数组的应用
int main()
{
	int arr1[] = { 1,2,3,4,5 };
	int arr2[] = { 2,3,4,5,6 };
	int arr3[] = { 3,4,5,6,7 };

	int* parr[3] = { arr1,arr2,arr3 };  //parr用来存放指针的数组

	int i = 0;
	for (i = 0; i < 3; i++)
	{
		int j = 0;
		for (j = 0; j < 5; j++)
		{
			printf("%d ", *(parr[i] + j));
           //printf("%d ",parr[i][j])  同上输出结果一致
		}
		printf("\n");
			
	}

	return 0;
}

二 数组指针

指向数组的指针,用来存放数组的地址

int * p1[10] ; // p1是指针数组

int (*p2)[10] ; // p2是数组指针,p2可以指向一个数组,该数组有10个元素,每个元素是int类型

cpp 复制代码
int main()
{
int arr[10]={0};

int *p=arr;

int(*p2)[10]=&arr;  //p2的类型是int(*)[10],&arr表示整个数组的地址

}
cpp 复制代码
//再次讨论数组名
int main()
{

	int arr[10] = { 0 };
	printf("%p\n", arr);  //000000C1EDB8FAE8
	printf("%p\n", arr+1);

	printf("%p\n", &arr[0]); //000000C1EDB8FAE8
	printf("%p\n", &arr[0]+1);


	printf("%p\n", &arr); //数组地址 000000C1EDB8FAE8
	printf("%p\n", &arr+1);

	int sz = sizeof(arr);
	printf("%d\n", sz); //40

	/*
	1.数组名通常表示的是数组首元素的地址
	2.但是有2个例外:
	   sizeof(数组名),这里的数组名表示是整个数组,计算的是整个数组的大小单位是字节
	   &数组名,这里的数组名表示的依然是整个数组,所以&数组名取出的是整个数组的地址
	
	*/

	return 0;
}
cpp 复制代码
# define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>


int main()
{

	int arr[] = { 1,2,3,4,5 };
	int* p = arr;
	int i = 0;
	for (i = 0; i < 5; i++)
	{
		printf("%d ", *(p + i));
	}

	return 0;
}
相关推荐
ChoSeitaku8 分钟前
链表循环及差集相关算法题|判断循环双链表是否对称|两循环单链表合并成循环链表|使双向循环链表有序|单循环链表改双向循环链表|两链表的差集(C)
c语言·算法·链表
DdddJMs__13514 分钟前
C语言 | Leetcode C语言题解之第557题反转字符串中的单词III
c语言·leetcode·题解
Fuxiao___17 分钟前
不使用递归的决策树生成算法
算法
我爱工作&工作love我22 分钟前
1435:【例题3】曲线 一本通 代替三分
c++·算法
娃娃丢没有坏心思1 小时前
C++20 概念与约束(2)—— 初识概念与约束
c语言·c++·现代c++
白-胖-子1 小时前
【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-统计数字
开发语言·c++·算法·蓝桥杯·等考·13级
workflower1 小时前
数据结构练习题和答案
数据结构·算法·链表·线性回归
好睡凯1 小时前
c++写一个死锁并且自己解锁
开发语言·c++·算法
Sunyanhui11 小时前
力扣 二叉树的直径-543
算法·leetcode·职场和发展
一个不喜欢and不会代码的码农1 小时前
力扣105:从先序和中序序列构造二叉树
数据结构·算法·leetcode