| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 560 人关注过本帖
标题:难解的错误啊,你在哪
只看楼主 加入收藏
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
结帖率:100%
收藏
 问题点数:0 回复次数:5 
难解的错误啊,你在哪
#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 insert(LNode *L,LNode *q)
{
     LNode *p;
     p=(LNode *)malloc(sizeof(LNode));
     p->data=q->data;
     p->next=L->next;
     L->next=p;
   
   
}//插入某 一元素
void Mergelist_L(LNode *La,LNode *Lb){
     //已知的单链表La和Lb的元素按值非递减排列
     //归并La和Lb得到新的单链表Lc,Lc的元素也按值非递减排列。
     LNode *pa,*pb;
     Lc=(LNode *)malloc(sizeof(LNode));
     
     Lc->next=NULL;
     pa=La->next; pb=Lb->next;  
     while(pa && pb)
     {
           if(pa->data < pb->data)
           {
                insert(Lc,pa); pa=pa->next;
           }
           else if(pa->data > pb->data)
           {insert(Lc,pb); pb=pb->next;}
           else {insert(Lc,pa); pa=pa->next; pb=pb->next;}  
     }
   
          while(pa)
          {insert(Lc,pa);  pa=pa->next;}
          while(pb)
          {insert(Lc,pb); pb=pb->next;}//将剩余段插入Lc中
     while(Lc->next!=NULL)
     {
           Lc=Lc->next;
           cout <<Lc->data << " ";
     }
     cout << endl;
}
void mix(LNode *La,LNode *Lb)
{
     LNode *Lc,*pa,*pb;
     Lc=(LNode *)malloc(sizeof(LNode));
     Lc->next=NULL;
     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 {insert(Lc,pa); pa=pa->next; pb=pb->next;}  
     }
     while(Lc->next!=NULL)
     {
           Lc=Lc->next;
           cout <<Lc->data << " ";
     }
     cout << endl;
}
void differ(LNode *La,LNode *Lb)
{
     LNode *pa,*pb,*Lc;
     Lc=(LNode *)malloc(sizeof(LNode));
     Lc->next=NULL;
     pa=La->next;
     pb=Lb->next;
     while(pa && pb)
     {
           if(pa->data < pb->data)
           {
               insert(Lc,pa); pa=pa->next;
           }
           else if(pa->data > pb->data)
           { pb=pb->next;}
           else { pa=pa->next; pb=pb->next;}  
     }
   
          while(pa)
          {insert(Lc,pa);  pa=pa->next;}
           while(Lc->next!=NULL)
     {
           Lc=Lc->next;
           cout <<Lc->data << " ";
     }
     cout << endl;
}
int main(){

     LNode *La,*Lb,*Lc;
     int a,b;
     cout <<"请输入A链表中元素的数目";
     cin >> a;
     cout <<"请按非递增顺序输入A链表中的元素";
     createlist_L(La,a);
     cout <<"请输入B链表中元素的数目";
     cin >> b;
     cout <<"请按非递增顺序输入B链表中的元素";
     createlist_L(Lb,b);
     cout <<"AnB   ";  mix(La,Lb);
     cout <<"AUB  ";  Mergelist_L(La,Lb);
     differ <<"A-B  "; differ(La,Lb);
      
     return 0;
}
     
     求高手帮忙看看      
搜索更多相关主题的帖子: include 元素 
2011-09-26 08:35
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
收藏
得分:0 
我是一个新手,帮帮忙,可伶一下我,其实三个函数基本上一样,可能错误也一样,没法运行啊
2011-09-26 08:37
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
收藏
得分:0 
我先上课去了,希望回来能看到回复啊,谢谢各位大哥了,麻烦了
2011-09-26 09:24
czsbc
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
帖 子:469
专家分:1700
注 册:2008-12-13
收藏
得分:0 
程序代码:
//到处是这贴。




#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 insert(LNode *L,LNode *q)

 {
      LNode *p;
      p=(LNode *)malloc(sizeof(LNode));
      p->data=q->data;
      p->next=L->next;
      L->next=p;
  
   
}//插入某 一元素
void Mergelist_L(LNode *La,LNode *Lb){
      //已知的单链表La和Lb的元素按值非递减排列
      //归并La和Lb得到新的单链表Lc,Lc的元素也按值非递减排列。
      LNode *pa,*pb,*Lc;
      Lc=(LNode *)malloc(sizeof(LNode));
    
      Lc->next=NULL;
      pa=La->next; pb=Lb->next;
      while(pa && pb)
      {
            if(pa->data < pb->data)
            {
                 insert(Lc,pa); pa=pa->next;
            }
            else if(pa->data > pb->data)
            {insert(Lc,pb); pb=pb->next;}
            else {insert(Lc,pa); pa=pa->next; pb=pb->next;}
      }
  
          while(pa)
           {insert(Lc,pa);  pa=pa->next;}
           while(pb)
          {insert(Lc,pb); pb=pb->next;}//将剩余段插入Lc中
      while(Lc->next!=NULL)
      {
            Lc=Lc->next;
            cout <<Lc->data << " ";
      }
      cout << endl;

 }

 void mix(LNode *La,LNode *Lb)

 {
      LNode *Lc,*pa,*pb;
      Lc=(LNode *)malloc(sizeof(LNode));
      Lc->next=NULL;
      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 {insert(Lc,pa); pa=pa->next; pb=pb->next;}
      }
     while(Lc->next!=NULL)
      {
            Lc=Lc->next;
            cout <<Lc->data << " ";
      }
      cout << endl;

 }

 void differ(LNode *La,LNode *Lb)

 {
      LNode *pa,*pb,*Lc;
      Lc=(LNode *)malloc(sizeof(LNode));
      Lc->next=NULL;
      pa=La->next;
      pb=Lb->next;
      while(pa && pb)
      {
            if(pa->data < pb->data)
            {
                insert(Lc,pa); pa=pa->next;
            }
            else if(pa->data > pb->data)
            { pb=pb->next;}
            else { pa=pa->next; pb=pb->next;}
      }
  
          while(pa)
           {insert(Lc,pa);  pa=pa->next;}
            while(Lc->next!=NULL)
      {
            Lc=Lc->next;
            cout <<Lc->data << " ";
      }
      cout << endl;

 }

 int main(){

     LNode *La,*Lb;
      int a,b;
      cout <<"请输入A链表中元素的数目";
     cin >> a;
      cout <<"请按非递增顺序输入A链表中的元素";
     createlist_L(&La,a);
      cout <<"请输入B链表中元素的数目";
     cin >> b;
      cout <<"请按非递增顺序输入B链表中的元素";
     createlist_L(&Lb,b);
      cout <<"AnB   ";  mix(La,Lb);
     cout <<"AUB  ";  Mergelist_L(La,Lb);
      cout <<"A-B  "; differ(La,Lb);
      
     return 0;

 }
2011-09-26 12:37
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
收藏
得分:0 
不好意思,我发了太多垃圾
2011-09-26 13:12
楠墨斗鱼
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2011-9-14
收藏
得分:0 
回复 4楼 czsbc
谢谢你的帮忙,现在问题解决了,第一次发帖,不太懂,请见谅
2011-09-26 13:18
快速回复:难解的错误啊,你在哪
数据加载中...
 
   



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

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