上题目,下面上一个分析:
n = 10, i = 9, pa[6] = pa[6] + pa[9];
........
过程中出现pa[6] + pa[6],此时的pa[6] != 7,而是现内存下的值pa[6] = 0 + 9 + 8 + 7 = 24
pa[6] = pa[6] + pa[6] = 48
最终pa[6] = 0 + (9 + 8 + 7) + (9 + 8 + 7) + 6 + 5 + 4 + 3 + 2 = 68
#include <stdio.h> void fun(int *pa, int n) { int i; for (i = n - 1; i > 0; i--) *(pa+6) += pa[i]; } int main(void) { int a[10] = {1,2,3,4,5,6,7,8,9,0}; int m = 10; fun(a,m); printf("The a[6] %d\n",a[6]); return 0; }
输出结果:
The a[6] 68
Life is mess, don't let mess mess us.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了