又见指针

昨天在CSDN上看有个提了这个问题,好久没看指针了,当时还真有点迷糊,调试了下就明白了
int main()

{

	int a[3] = {1,2,3};

	int (*p)[3] = &a;

}



说明:

1.int (*p)[3]:	p是一个指向整型数组的指针,指针指向的是一个数组,也就是数组指针

  int *p[3]:	是一个由三个指针做为数组元素组成的整型数组,数组里面存放的是指针,即指针数组

2.int (*p)[3] = &a;	将指针p指向了数组a的首地址

3.此时*p指向的是数组a中第一个元素的首地址

4.如果将p++,则此时p指向了数组a的末地址,也就是a[3]的地址,跨越的是一个数组的长度

5.如果将*p++,则此时*p指向的是a[1]的地址,跨越的是一个数组元素的长度

6.p是指向数组a的首地址,是个二级指针;*p是指向数组a的第一个元素的地址,是一个一级指针



最后详细看下输出下面的值就明白了

int main()

{

	int a[3] = {1,2,3};

	int (*p)[3] = &a;



	cout<<*p[0]<<endl;	//此时输出的是a[0]的值

	cout<<*(p[1]-1)<<endl;	//输出a[2]的值

	cout<<(*p)[2]<<endl;	//输出a[2]的值

	cout<<p[0][2]<<endl;	//输出a[2]的值

	cout<<p<<endl;		//输出p的地址值

	cout<<*p<<endl;		//输出*p的地址值

	p++;cout<<"After p++"<<endl;

	cout<<p<<endl;		//输出p的地址值

	cout<<*p<<endl;		//输出*p的地址值

	cout<<**(p-1)<<endl;	//输出a[0]的值

	cout<<*(*p-1)<<endl;	//输出a[2]的值



	return 0;

}

【源码免费下载链接】:https://renmaiwang.cn/s/x7agi C++实现银行排队系统本文详细介绍了使用C++语言实现银行排队系统的设计和实现。银行排队系统是银行营业厅中常的一种场景,顾客需要排队等待办理业务,因此设计一个高效的排队系统对于银行的服务质量和顾客体验至关重要。在这个系统中,我们使用链表来实现队列,链表是一个动态的数据结构,可以根据需要动态地添加或删除节点。我们定义了一个链表结构体`linkqueue`,它包含前端指针`front`、后端指针`rear`和长度`length`三个成员变量。在这个系统中,我们实现了三个基本的操作:初始化队列、加入队列和出队列。`initqueue`函数用于初始化队列,`enterqueue`函数用于将顾客加入队列,`popqueue`函数用于将顾客从队列中删除。在加入队列时,我们需要记录顾客的编号、到达时间和离开时间,这些信息将用于统计顾客的排队时长和服务时间。在出队列时,我们需要将顾客从队列中删除,并更新队列的长度。为了实现银行排队系统,我们还需要实现两个辅助函数:`getmin`函数用于获取当前队列中人数最少的队列,`getmax`函数用于获取当前队列中人数最多的队列。在顾客来到银行时,我们需要记录顾客的编号和到达时间,并将其加入到人数最少的队列中。在顾客离开时,我们需要将其从队列中删除,并更新队列的长度。本文中的代码实现了上述功能,提供了一个完整的银行排队系统的实现方案。通过这个系统,银行可以更好地管理顾客的排队,提供更好的服务体验。知识点:* 链表的实现和应用* 队列的实现和应用* 结构体的定义和应用* 指针的应用* 函数的定义和应用* 输入输出操作的实现* 条件语句和循环语句的应用本文提供了一个完整的银行排队系统的实现方案,展示了C++语言在实现复杂系统中的应用,可以作为学习C++语言和数据结构的参考
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值