「已注销」 2022-03-03 11:33 采纳率: 25%
浏览 210
已结题

请问顺序表中插入元素的操作 指针后移语句:for ( p = &(L.elem[L.length-1]); p >= q; --p) 中的--p怎么理解?

如题。指针后移不应该是++p吗?为什么是--p?

完整代码:
//第i个位置插入学生信息
Status ListInsert_Sq(SqList &L, int i){
Student *newbase;
Student *q;
Student *p;
printf("输入在哪个位置插入新元素:");
scanf("%d",&i);
if (i < 1||i > L.length+1) return 0; // 插入位置不合法
if (L.length >= L.listsize){
//当前存储空间已满
newbase=(Student *)realloc(L.elem,(LIST_INIT_SIZE+LISTINCREMENT)*sizeof(Student));
if(!newbase) exit(OVERFLOW);
L.elem=newbase; // 新基址
L.listsize+=LISTINCREMENT;
} // 增加存储容量
q = &(L.elem[i-1]); // q指示插入位置
for ( p = &(L.elem[L.length-1]); p >= q; --p)
*(p+1) = *p; // 插入位置及之后的元素右移
printf("请输入插入学生信息\n");
printf("请输入学生的学号:\n");
scanf("%s",&q->no);
printf("请输入学生的姓名:\n");
scanf("%s",&q->name);
printf("请输入学生的电话:\n");
scanf("%s",&q->phone);
++ L.length; // 表长增1
return 1;
}

img

  • 写回答

1条回答 默认 最新

  • 一只蚂蝼 2022-03-03 11:45
    关注

    你的理解是没问题的--p确实不是后移而是前移

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月12日
  • 创建了问题 3月3日