【C语言进阶】指针的加减

目录

一、存放指针的变量的加减

二、存放指针的变量的自增自减

三、两个指针相减


一、存放指针的变量的加减

        如果指针变量a已指向数组中的一个元素,则a+1指向同一数组的下一个元素,a-1表示指向同一数组的上一个元素。注意:执行a+1时并不是将p的值(地址)简单的加一,而是加上一个数组元素所占的字节数。

即:
        int 型指针+1    :地址+4
        short型指针+1 :地址+2
        char型指针+1  :地址+1

综上:
        数据类型* a;
        a + n ==  a中存放的地址 + n * sizeof(A的数据类型) ;


存放指针的变量能加也能减,但不管加减都要小心越界。

上面的写法等价于:

二、存放指针的变量的自增自减

  • 存放指针的变量有两种: 数组变量、指针变量。
  • 数组变量不能自增和自减,因为C语言规定它必须存放指向数组起始地址的指针,不能修改,但自增和自减会修改变量的值,所以数组变量不能自增和自减。
  • 指针变量可以自增和自减,和 +1 / -1 没有区别。

三、两个指针相减

 两个指针不可以相加,但可以相减,相减结果为在数组中的下标之差。

	int a[] = { 1, 2, 3, 4, 5 };
	cout << &a[3] - &a[0] << endl; 


------------------------END-------------------------

才疏学浅,谬误难免,欢迎各位批评指正。

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
引用中提到了设计一个一元稀疏多项式简单计算器的基本功能,其中包括输入并建立多项式,以及输出多项式。引用中给出了一种数据结构的定义,用于表示多项式的系数和指数。根据这些信息,我们可以设计一个算法来实现一元多项式的相加减。 首先,我们可以通过链表的方式来表示多项式,每个节点存储一个项的系数和指数,并且按照指数的大小有序排列。我们可以定义一个结构体来表示每个节点,其中包括系数和指数的成员变量,以及一个指向下一个节点的指针。这样,我们就可以通过遍历链表来访问每个项。 接下来,对于两个多项式的相加减,我们可以定义两个指针分别指向两个多项式的头节点。然后,我们可以按照指数的大小比较,逐个比较节点,并将结果保存到一个新的链表中。具体步骤如下: 1. 创建一个新的链表,用于保存相加减后的多项式结果。 2. 初始化两个指针,分别指向两个多项式的头节点。 3. 比较两个节点的指数大小: - 如果两个节点的指数相等,将它们的系数相加,并将结果插入到新链表中。 - 如果一个节点的指数小于另一个节点,将较小指数的节点插入到新链表中,并将指向该节点的指针向后移动一位。 - 如果一个多项式的所有节点都已经处理完,将另一个多项式剩余的节点直接插入到新链表中。 4. 重复步骤3,直到两个多项式的所有节点都被处理完毕。 5. 返回新链表作为相加减后的多项式结果。 这样,我们就可以实现一元多项式的相加减操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

烛火萤辉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值