| 网站首页 | 业界新闻 | 小组 | 交易 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
共有 727 人关注过本帖
标题:关于串的链接问题
只看楼主 加入收藏
yxy1995523
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2012-11-15
结帖率:66.67%
收藏
已结贴  问题点数:15 回复次数:12 
关于串的链接问题
STRNODE *str_con(STRNODE *s1,STRNODE *s2)   
{ //将字符串S2连接到S1串的后面,两个串合并成一个串,放到S1串中/
        STRNODE *p,*q,*s;
        int i;
    p=s1->next;
    q=s2->next;
   
    do{
        p=p->next;
    }while(p->next==NULL);
//    p=q;

    do{
   s=(STRNODE *)malloc(sizeof(STRNODE));
     s->ch=q->ch;
     p->next=s;
     p=s;
//     p->next=NULL;
     q=q->next;
    }while(q->next=NULL);

    return p;
我实在分析不通我的问题在哪里,我在草稿纸上验证了无数遍 ,都没发现问题在哪里,但是在机器上只返回原始的P ,求指点
搜索更多相关主题的帖子: 字符串 return 
2014-04-25 22:37
kwxx
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:309
专家分:913
注 册:2009-5-11
收藏
得分:5 
需要重新开辟空间,复制s2中的字符,还仅仅是连接两个串?
2014-04-25 22:50
kwxx
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:309
专家分:913
注 册:2009-5-11
收藏
得分:0 
STRNODE *str_con(STRNODE *s1,STRNODE *s2)   
{
        STRNODE *p,*q,*s;
        int i;
    p=s1->next;
    q=s2->next;
   
    do{
        p=p->next;
    }while(p->next==NULL);

    do{
    s=(STRNODE *)malloc(sizeof(STRNODE));
     s->ch=q->ch;
     p->next=s;
     p=s;
     q=q->next;
    }while(q!=NULL); //你的条件显然错了,不该是赋值
    p->next=NULL;  //串尾加上结束标致
    return s1;        //注意到p在变,返回应该是s1
}

[ 本帖最后由 kwxx 于 2014-4-25 23:34 编辑 ]
2014-04-25 23:01
yxy1995523
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2012-11-15
收藏
得分:0 
回复 2 楼 kwxx
我的意思是重新为p 开辟节点,然后朝里面塞入q的值
2014-04-25 23:08
kwxx
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:309
专家分:913
注 册:2009-5-11
收藏
得分:0 
楼主试试上边改的。
2014-04-25 23:12
yxy1995523
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2012-11-15
收藏
得分:0 
回复 5 楼 kwxx
试过了  ,    STRNODE *p,*q,*s;
//    int i;
    p=s1->next;
    q=s2->next;
   
    while(p->next!=NULL)
    {
        p=p->next;
    }
//    p=q;

    do{
   s=(STRNODE *)malloc(sizeof(STRNODE));
     s->ch=q->ch;
     p->next=s;
     p=s;
//     p->next=NULL;
     q=q->next;
    }while(p!=NULL);
p->next=NULL;
    return s1;

其中,感觉应该是while(p!=NULL); 还是没用,还只是返回原始的P的串。
while(p==NULL)我也试过,一样的结果 ,我感觉
do{
   s=(STRNODE *)malloc(sizeof(STRNODE));
     s->ch=q->ch;
     p->next=s;
     p=s;
//     p->next=NULL;
     q=q->next;
    }while(p!=NULL);
这一段代码根本没执行。
2014-04-25 23:18
kwxx
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:309
专家分:913
注 册:2009-5-11
收藏
得分:0 
不好意思,刚才蒙了。循环条件应该是 q!=NULL  你别改成p!
2014-04-25 23:37
yxy1995523
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2012-11-15
收藏
得分:0 
回复 7 楼 kwxx
不管是p还是q都对最后的结果没有任何影响,返回的结果依旧是没有连接成功的P ,我有点无奈了
2014-04-26 08:38
砖家的谎言
Rank: 12Rank: 12Rank: 12
等 级:禁止访问
威 望:30
帖 子:693
专家分:3898
注 册:2013-12-6
收藏
得分:5 
有点看不懂,你这是C++ 还是C呀

我不是砖家,要努力成为砖家。
2014-04-26 09:06
kwxx
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:309
专家分:913
注 册:2009-5-11
收藏
得分:0 
你单独输出一下,你的s1,和s2,看它们是否有误?
2014-04-26 09:06
快速回复:关于串的链接问题
数据加载中...
 
   



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

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