| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 427 人关注过本帖
标题:还是这帖,还是我发的又有了新的问题,为什么同样的算法在函数内部正确,将 ...
只看楼主 加入收藏
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
结帖率:100%
收藏
 问题点数:0 回复次数:2 
还是这帖,还是我发的又有了新的问题,为什么同样的算法在函数内部正确,将多个函数放在一起就错了呢?到底是什么问题?麻烦大家看看,谢啦!
#include<iostream>
using namespace std;
typedef struct LNode{
        int   data;
        struct LNode *next;
}LNode;
      
void createlist_L(LNode* *L,int n)
{
      //逆序输入N个元素的值,建立带表头结点的单链表L
      LNode *p;
      int i;
      (*L)=(LNode *)malloc(sizeof(LNode));
      (*L)->next = NULL;//先建立一个带头结点的单链表
      for(i=n;i>0;--i)
      {
           p=(LNode *)malloc(sizeof(LNode));//生成新结点
           scanf("%d",&p->data);
           p->next = (*L)->next;//插入到表头
           (*L)->next = p;
      }
}//creatlist L
void Mergelist_L(LNode *La,LNode *Lb){
      //已知的单链表La和Lb的元素按值非递减排列
      //归并La和Lb得到新的单链表Lc,Lc的元素也按值非递减排列。
      LNode *pa,*pb,*Lc,*pc;
      Lc=(LNode *)malloc(sizeof(LNode));
      pc=Lc;
      pa=La->next; pb=Lb->next;
      while(pa && pb)
      {
            if(pa->data < pb->data)
            {
                pc->next=pa;
                pa=pa->next;
                pc=pc->next;
            }
            else if(pa->data > pb->data)
            {
                pc->next=pb;
                pb=pb->next;
                pc=pc->next;
            }
            else
            {
                pc->next=pa;
                pa=pa->next;
                pb=pb->next;
                pc=pc->next;
            }
      }
      while(pa)      
      {
          pc->next=pa;
          pa=pa->next;
          pc=pc->next;
      }
      while(pb)
      {
          pc->next=pb;
          pb=pb->next;
          pc=pc->next;
      }//将剩余段插入Lc中
     
      while(Lc->next!=NULL)
      {
            Lc=Lc->next;
            cout <<Lc->data << " ";
      }
      cout << endl;
}
void mix_L(LNode *La,LNode *Lb)
{
     LNode *Lc,*pa,*pb,*pc;
     Lc=(LNode *)malloc(sizeof(LNode));
     pc=Lc;
     pa=La->next;
     pb=Lb->next;
     while(pa && pb)
     {
           if(pa->data < pb->data)
           {
                 pa=pa->next;
           }
           else if(pa->data > pb->data)
           {     pb=pb->next;}
           else
           {
                 pc->next=pa;
                 pa=pa->next;
                 pb=pb->next;
                 pc=pc->next;
           }  
     }
    pc->next=NULL;
    while(Lc->next!=NULL)
     {
           Lc=Lc->next;
           cout <<Lc->data << " ";
     }
     cout << endl;
}
void differ_L(LNode *La,LNode *Lb)
{
     LNode *pa,*pb,*pc,*Lc;
     Lc=(LNode *)malloc(sizeof(LNode));
     pc=Lc;
     pa=La->next;
     pb=Lb->next;
     while(pa && pb)
     {
           if(pa->data < pb->data)
           {
                pc->next=pa;
                pa=pa->next;
                pc=pc->next;
           }
           else if(pa->data > pb->data)
           { pb=pb->next;}
           else { pa=pa->next; pb=pb->next;}  
     }
   
          while(pa)
          {
                pc->next=pa;
                pa=pa->next;
                pc=pc->next;
          }
     pc->next=NULL;
     while(Lc->next!=NULL)
     {
           Lc=Lc->next;
           cout <<Lc->data << " ";
     }
     cout << endl;
}
int main()
{
    LNode *La,*Lb;
    int a,b;
    cout <<"请输入A链表中元素的数目"<<endl;
    cin >> a;
    cout <<"请按非递增顺序输入A链表中的元素"<<endl;
    createlist_L(&La,a);
    cout <<"请输入B链表中元素的数目"<<endl;
    cin >> b;
    cout <<"请按非递增顺序输入B链表中的元素"<<endl;
    createlist_L(&Lb,b);
    cout <<"AUB: ";
    Mergelist_L(La,Lb);
    cout <<"AnB: ";
    mix_L(La,Lb);
    cout <<"A-B: ";
    differ_L(La,Lb);
    system("pause");
    return 0;
}
收到的鲜花
  • charlin2011-09-27 17:45 送鲜花  3朵   附言:我很赞同
搜索更多相关主题的帖子: include 元素 
2011-09-27 07:36
czsbc
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:469
专家分:1700
注 册:2008-12-13
收藏
得分:0 
被你发现了这个问题,还是让我来解答吧。
在做Mergelist_L(La,Lb);时并没有重新分配新的内存空间,只是改变了指针的指向。
所以做完后,La,Lb,实际上就是在一条链上了,只是指向这条链的不同位置(也有可能在相同位置:最后一个数相同时)。
后面再做mix_L(La,Lb);differ_L(La,Lb);时得到的就是两段(以La或Lb所指向的结点而分)。
所以我在改你的这个程序时就没有再用这种方法了。呵呵。。。
 while(pa)      
      {
           pc->next=pa;
           pa=pa->next;
           pc=pc->next;
       }
       while(pb)
       {
           pc->next=pb;
           pb=pb->next;
           pc=pc->next;
       }//将剩余段插入Lc中
 另外这里已有人指出可以直接连的,不用循环了。
 
收到的鲜花
  • charlin2011-09-27 17:46 送鲜花  3朵   附言:我很赞同
2011-09-27 16:12
charlin
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-9-27
收藏
得分:0 
不好意思,我怎么给发问者评分了呢?楼上的说法很对,虽然有点懵懂,因为我也遇到过这种问题,最终没有弄懂是什么原因,只是重新编写了一段代码
2011-09-27 17:49
快速回复:还是这帖,还是我发的又有了新的问题,为什么同样的算法在函数内部正确 ...
数据加载中...
 
   



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

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