| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 444 人关注过本帖
标题:for()循环指针出错!!!
只看楼主 加入收藏
追寻XT
Rank: 2
等 级:论坛游民
威 望:1
帖 子:37
专家分:32
注 册:2014-8-20
结帖率:83.33%
收藏
已结贴  问题点数:15 回复次数:2 
for()循环指针出错!!!
程序代码:
int DellList(List *L,int i,STU *e){
    STU *p;
    if(i<1||i>L->length)  return 0;
    *e=L->Stu[i-1];
    for(p=&(L->Stu[i-1]);p<&(L->Stu[L->length-1]);p++)
           *p=*(p++);
    L->length--;
    return 1;
} //删除元素 

以上是线性表中删除元素的函数,但是不正确,错误处在循环体指针步长加1,而循环条件中P又加1,导致错误,按照这个思路,提供4中改法:
程序代码:
int DellList(List *L,int i,STU *e){
    STU *p;
    if(i<1||i>L->length)  return 0;
    *e=L->Stu[i-1];
    for(p=&(L->Stu[i-1]);p<&(L->Stu[L->length-1]);p++)
           *p=*(p+1);
    L->length--;
    return 1;
} //删除元素 




程序代码:
int DellList(List *L,int i,STU *e){
    STU *p;
    if(i<1||i>L->length)  return 0;
    *e=L->Stu[i-1];
    for(p=&(L->Stu[i-1]);p<&(L->Stu[L->length-1]);)
           *p=*(p++);
    L->length--;
    return 1;
} //删除元素 


程序代码:
int DellList(List *L,int i,STU *e){
    STU *p;
    if(i<1||i>L->length)  return 0;
    *e=L->Stu[i-1];
    for(p=&(L->Stu[i-1]);p<&(L->Stu[L->length-1]);p++)
           *p=*p++;
    L->length--;
    return 1;
} //删除元素 


程序代码:
int DellList(List *L,int i,STU *e){
    STU *p;
    if(i<1||i>L->length)  return 0;
    *e=L->Stu[i-1];
    for(p=&(L->Stu[i-1]);p<&(L->Stu[L->length-1]);)
           *p=*p++;
    L->length--;
    return 1;
} //删除元素 

但是只有第一种有效,问题在于其他的为是么没有作用???
2014-09-27 19:42
erty1001
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:4
帖 子:331
专家分:1433
注 册:2014-8-31
收藏
得分:15 
简单说说:
 原因很简单:
 *p=*(p++);
这种式子属于符合式子,你要学会分解,一般我们自己编程 先不写复合式子,等到了后期优化再写,或者加密需要再写

分解开就是
*p=*p;
p++;
看到问题没了? 至少应该是*p=*(++p);的形式才对
2014-09-27 20:09
追寻XT
Rank: 2
等 级:论坛游民
威 望:1
帖 子:37
专家分:32
注 册:2014-8-20
收藏
得分:0 
回复 2 楼 erty1001
++P也不行,前面的p也变了,尽量把它分成两句话来执行吧。
2014-09-28 19:09
快速回复:for()循环指针出错!!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.086650 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved