鱼C论坛

 找回密码
 立即注册
查看: 3156|回复: 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 编辑
  1. typedef struct LNode
  2. {
  3. char data;
  4. struct LNode;
  5. LNode *next;
  6. }
  7. node,*LinkList;//线性表单链表的存储结构
复制代码

这里 struct LNode ??; 是否需要成员没有写?

  1. L=(LinkList)malloc(sizeof(node));//假设p是LinkList型的变量,这行语句的意思是由系统生成一个L弄node型结点,同时将该节点的起始位置赋给指针p
  2.         for(i=n;i>0;--i)
  3.         {
  4.         p=(LinkList)malloc(sizeof(node));//生成新节结点
  5.         scanf(&p->data);
  6.         p->next=L->next;
  7.         L->next=p;
  8. }
复制代码


scanf用法如下
  1. int scanf(const char *format, ...)
复制代码

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

然后是链表。。。
  1.         p->next=L->next;
  2.         L->next=p;
复制代码


如果是头插入应该是
  1. p->next = h
  2. h = p
复制代码

如果是尾插入应该是
  1. t->next = p
  2. t = p
复制代码

这里的两个变量都在改变(注意)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 09:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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