标题:帮我改改这个程序 运行出来(链表头插法)
取消只看楼主
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
结帖率:83.33%
已结贴  问题点数:20 回复次数:4 
帮我改改这个程序 运行出来(链表头插法)
#include <stdio.h>
#include <stdlib.h>
typedef char ElemType;
typedef struct Node//atention the 'struct'
{
    ElemType data;
    struct Node* next;
}Node,*LinkList;
void GreateFormHead(LinkList L)//插法建立链表函数
{
    Node *s;//定义一个结点
    char c;
    int flag=1;
    L=(LinkList)malloc(sizeof(Node));//atention
    L->next=NULL;//头结点   这两句是初始化链表
    while(flag)
    {
        printf("输入字符:\n");
        c=getchar();
        if(c!='$')//atention  头插法核心步骤
        {
            s=(Node*)malloc(sizeof(Node));
            s->data=c;
            s->next=L->next;
            L->next=s;
        }
        else
                flag=0;
    }
}
void printf(Node *L)//输出函数   *L是头结点
{
    Node *q;
    q=L->next;
    while(q!=NULL)
    {
        //putchar(L->data);//atention
        printf("%c",q->data);
        q=q->next;
    }
   
}
int main()
{
        LinkList L;   
    GreateFormHead(L);//调用时只用函数名
    printf(L);
    return 0;
     
}
搜索更多相关主题的帖子: Node data next 结点 printf 
2018-04-06 16:35
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
得分:0 
回复 2楼 吹水佬
非常感谢 这种方法我懂了 但是你知道我原来错在哪里吗
2018-04-06 17:40
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
得分:0 
回复 2楼 吹水佬
你的程序中for (; L; L=L->next)的循环条件是当L=NULL时就跳出吗?
2018-04-06 17:47
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
得分:0 
回复 5楼 lanke711
c=getchar();后面的getchar();有什么用
傻傻的问一下为什么是逆序输出?
2018-04-06 22:59
堃周
Rank: 1
等 级:新手上路
帖 子:21
专家分:0
注 册:2018-4-6
得分:0 
回复 5楼 lanke711
非常感谢
2018-04-07 15:04



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-485795-1-1.html




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

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