| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 465 人关注过本帖
标题:求查错,语法没错,运行停不了,c 语言指针练习
只看楼主 加入收藏
yejiangnan
Rank: 1
等 级:新手上路
帖 子:9
专家分:2
注 册:2014-4-23
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:6 
求查错,语法没错,运行停不了,c 语言指针练习
//   题目:建立1个单链表,把单链表拆分成3个循环链表,循环链表为数字,字符,其他特殊符号,我的代码运行后,一直重复输出最后一个元素,怎么解决,求大神
#include<stdio.h>
#define elemtype char
struct link
{
    elemtype data;
    link *next;
};
link *la,*lb,*lc;
link *hcreat()   // 头插法建立单链表
{
    link *p,*q;
    p=new link;
    p->next =NULL;
    elemtype i;
    printf("请输入链表元素,先进的在末尾,输入#结束\n");
    scanf("%c",&i);
    while(i!='#')
    {
        q=new link;
        q->next =NULL;
        q->data  =i;
        q->next =p->next ;
        p->next =q;
        scanf("%c",&i);
    };
    return p;
};
void div(link *s)     //拆分单链表成3个循环链表,分别为数字,字符,其他
{
    la=new link;lb=new link; lc=new link;
    la->next=NULL;lb->next=NULL;lc->next=NULL;
    la->data='#';lb->data='#';lc->data='#';
    link *p,*hla,*hlb,*hlc;
    p=s->next;hla=la;hlb=lb;hlc=lc;
    while(p!=NULL)
    {
        if(((p->data)>='0')&&((p->data)<='9'))
        {
            hla->next=p;
            hla=p;
        }
        else if(((p->data>='a')&&(p->data<='z'))||((p->data>='A')&&(p->data<='Z')))
        {
            hlb->next=p;
            hlb=p;
        }
        else
        {
            hlc->next=p;
            hlc=p;
        }
    };
    hla->next=la;
    hlb->next=lb;
    hlc->next=lc;
};
void print1(link *p)    // 输出单链表
{
    link *q;
    q=p->next ;
    while((q->next)!=NULL)
    {
        printf("%c",q->data );
        q=q->next;
    }
    printf("%c",q->data );
    return ;
   
}
void print2(link *p)    //输出循环链表
{
    link *q;
    q=p->next;
    while(q->next->data!='#')
    {
        printf("%c",q->data );
        q=q->next;
    }
    printf("%c",q->data );
    return ;
}
void main()
{
    link *px;
    px=hcreat();
    print1(px);
    div(px);
    print2(la);
    print2(lb);
    print2(lc);
}
搜索更多相关主题的帖子: 特殊符号 include 元素 
2014-04-23 12:31
鸥翔鱼游
Rank: 5Rank: 5
等 级:职业侠客
帖 子:182
专家分:323
注 册:2014-4-19
收藏
得分:0 
好文章。总是支持一下的
2014-04-23 12:50
yejiangnan
Rank: 1
等 级:新手上路
帖 子:9
专家分:2
注 册:2014-4-23
收藏
得分:0 
回复 2 楼 鸥翔鱼游
支持一下,能解决不?不要路过撇一眼啊
2014-04-23 12:57
ying8501
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:6
帖 子:1092
专家分:1446
注 册:2008-11-24
收藏
得分:10 
//你自己对照一下吧。特别注意红色代码。
#include<stdio.h>
#define elemtype char
struct link
{
    elemtype data;
    link *next;
};

link *la,*lb,*lc;

link *hcreat()   // 头插法建立单链表
{
    link *p,*q;
    p=new link;
    p->next =NULL;
    elemtype i;

    printf("请输入链表元素,先进的在末尾,输入#结束\n");
    scanf("%c",&i);

    while(i!='#')
    {
        q=new link;        
        q->data  =i;
        q->next =p;
        p=q;
        scanf("%c",&i);
    }
    return p;
}

void div(link *s)     //拆分单链表成3个循环链表,分别为数字,字符,其他
{
    la=new link;
    lb=new link;
    lc=new link;

    la->next=NULL;lb->next=NULL;lc->next=NULL;
    la->data='#';lb->data='#';lc->data='#';

    link *p,*hla,*hlb,*hlc;
    p=s;
    hla=la;
    hlb=lb;
    hlc=lc;
    while(p!=NULL)
    {
        if(((p->data)>='0')&&((p->data)<='9'))
        {
            hla->next=p;
            hla=p;
        }
        else if(((p->data>='a')&&(p->data<='z'))||((p->data>='A')&&(p->data<='Z')))
        {
            hlb->next=p;
            hlb=p;
        }
        else
        {
            hlc->next=p;
            hlc=p;
        }
        p=p->next;
    }
    hla->next=la;
    hlb->next=lb;
    hlc->next=lc;
}
void print1(link *p)    // 输出单链表
{
    while(p!=NULL)
    {
        printf("%c",p->data );
        p=p->next;
    }
    printf("\n\n");
    return ;
   
}
void print2(link *p)    //输出循环链表
{
    link *q;
    q=p->next;
    while(q->data!='#')
    {
        printf("%c",q->data );
        q=q->next;
    }
    printf("\n");   
    return ;
}
void main()
{
    link *px;
    px=hcreat();
    print1(px);
    div(px);
    print2(la);
    print2(lb);
    print2(lc);
}
2014-04-23 21:38
yejiangnan
Rank: 1
等 级:新手上路
帖 子:9
专家分:2
注 册:2014-4-23
收藏
得分:0 
回复 4 楼 ying8501
感谢,加个好友吧
2014-04-27 21:02
yejiangnan
Rank: 1
等 级:新手上路
帖 子:9
专家分:2
注 册:2014-4-23
收藏
得分:0 
已解决;
正确代码:#include<stdio.h>
 #define elemtype char
 struct link
 {
     elemtype data;
     link *next;
 };

 link *la,*lb,*lc;

 link *hcreat()   // 头插法建立单链表
{
     link *p,*q;
     p=new link;
     p->next =NULL;
     elemtype i;

     printf("请输入链表元素,先进的在末尾,输入#结束\n");
     scanf("%c",&i);

     while(i!='#')
     {
         q=new link;        
         q->data  =i;
         q->next =p;
         p=q;
         scanf("%c",&i);
     }
     return p;
 }

 void div(link *s)     //拆分单链表成3个循环链表,分别为数字,字符,其他
{
     la=new link;
     lb=new link;
     lc=new link;

     la->next=NULL;lb->next=NULL;lc->next=NULL;
     la->data='#';lb->data='#';lc->data='#';

     link *p,*hla,*hlb,*hlc;
     p=s;
     hla=la;
     hlb=lb;
     hlc=lc;
     while(p!=NULL)
     {
         if(((p->data)>='0')&&((p->data)<='9'))
         {
             hla->next=p;
             hla=p;
         }
         else if(((p->data>='a')&&(p->data<='z'))||((p->data>='A')&&(p->data<='Z')))
         {
             hlb->next=p;
             hlb=p;
         }
         else
         {
             hlc->next=p;
             hlc=p;
         }
         p=p->next;
    }
     hla->next=la;
     hlb->next=lb;
     hlc->next=lc;
 }
void print1(link *p)    // 输出单链表
{
     while(p!=NULL)
     {
         printf("%c",p->data );
         p=p->next;
     }
     printf("\n\n");
     return ;
     
 }
void print2(link *p)    //输出循环链表
{
     link *q;
     q=p->next;
     while(q->data!='#')
     {
         printf("%c",q->data );
         q=q->next;
     }
     printf("\n");   
     return ;
 }
 void main()
 {
     link *px;
     px=hcreat();
     print1(px);
     div(px);
     print2(la);
     print2(lb);
     print2(lc);
 }
2014-04-27 21:03
yejiangnan
Rank: 1
等 级:新手上路
帖 子:9
专家分:2
注 册:2014-4-23
收藏
得分:0 
已解决;
正确代码:#include<stdio.h>
 #define elemtype char
 struct link
 {
     elemtype data;
     link *next;
 };

 link *la,*lb,*lc;

 link *hcreat()   // 头插法建立单链表
{
     link *p,*q;
     p=new link;
     p->next =NULL;
     elemtype i;

     printf("请输入链表元素,先进的在末尾,输入#结束\n");
     scanf("%c",&i);

     while(i!='#')
     {
         q=new link;        
         q->data  =i;
         q->next =p;
         p=q;
         scanf("%c",&i);
     }
     return p;
 }

 void div(link *s)     //拆分单链表成3个循环链表,分别为数字,字符,其他
{
     la=new link;
     lb=new link;
     lc=new link;

     la->next=NULL;lb->next=NULL;lc->next=NULL;
     la->data='#';lb->data='#';lc->data='#';

     link *p,*hla,*hlb,*hlc;
     p=s;
     hla=la;
     hlb=lb;
     hlc=lc;
     while(p!=NULL)
     {
         if(((p->data)>='0')&&((p->data)<='9'))
         {
             hla->next=p;
             hla=p;
         }
         else if(((p->data>='a')&&(p->data<='z'))||((p->data>='A')&&(p->data<='Z')))
         {
             hlb->next=p;
             hlb=p;
         }
         else
         {
             hlc->next=p;
             hlc=p;
         }
         p=p->next;
    }
     hla->next=la;
     hlb->next=lb;
     hlc->next=lc;
 }
void print1(link *p)    // 输出单链表
{
     while(p!=NULL)
     {
         printf("%c",p->data );
         p=p->next;
     }
     printf("\n\n");
     return ;
     
 }
void print2(link *p)    //输出循环链表
{
     link *q;
     q=p->next;
     while(q->data!='#')
     {
         printf("%c",q->data );
         q=q->next;
     }
     printf("\n");   
     return ;
 }
 void main()
 {
     link *px;
     px=hcreat();
     print1(px);
     div(px);
     print2(la);
     print2(lb);
     print2(lc);
 }
2014-04-27 21:03
快速回复:求查错,语法没错,运行停不了,c 语言指针练习
数据加载中...
 
   



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

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