鱼C论坛

 找回密码
 立即注册
查看: 3485|回复: 1

大家看一下,为啥不出现插入元素的地方而是输入元素n直接就结束了

[复制链接]
发表于 2017-8-7 12:18:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
#include<stdlib.h>
typedef struct LNode
{
char data;
struct LNode;
LNode *next;
}
node,*LinkList;//线性表单链表的存储结构


void CreateList_L(LinkList &L,int n)
{       
        int i;
        LinkList p;
        L=(LinkList)malloc(sizeof(node));//假设p是LinkList型的变量,这行语句的意思是由系统生成一个L弄node型结点,同时将该节点的起始位置赋给指针p
        for(i=n;i>0;--i)
        {
        p=(LinkList)malloc(sizeof(node));//生成新节结点
        scanf(&p->data);
        p->next=L->next;
        L->next=p;
}
}//CreateList_l




void main()
{
LinkList L;
int n;
printf("请输入结点的个数");
scanf("%d",&n);
LinkList a;
CreateList_L(L,n);
}








想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-8-7 14:08:02 | 显示全部楼层
本帖最后由 json 于 2017-8-7 14:12 编辑
typedef struct LNode
{
char data;
struct LNode;
LNode *next;
}
node,*LinkList;//线性表单链表的存储结构
这里 struct LNode ??; 是否需要成员没有写?
 L=(LinkList)malloc(sizeof(node));//假设p是LinkList型的变量,这行语句的意思是由系统生成一个L弄node型结点,同时将该节点的起始位置赋给指针p
        for(i=n;i>0;--i)
        {
        p=(LinkList)malloc(sizeof(node));//生成新节结点
        scanf(&p->data);
        p->next=L->next;
        L->next=p;
}

scanf用法如下
int scanf(const char *format, ...)
这里的data是char类型,可以scanf("%c", &p->data);
这里在for循环里面,每次读取需要清空一下缓冲区,fflush(stdin);

然后是链表。。。
        p->next=L->next;
        L->next=p;

如果是头插入应该是
p->next = h
h = p
如果是尾插入应该是
t->next = p
t = p
这里的两个变量都在改变(注意)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-7-2 23:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表