zuimman 2019-04-15 21:06 采纳率: 0%
浏览 417

用链表存数据,为什么运行之后什么都没有

#include
#include
typedef struct node{
int data;
struct node *next;
}*sqlist;//定义链表结构

sqlist creatlist(int n){//创建单向链表
sqlist head,p,q;
head=p=(sqlist)malloc(sizeof(node));
for(int i=0;i q=(sqlist)malloc(sizeof(node));
q->data=i;
p->next=q;
p=q;
}
p->next=NULL;
return head;
}

void printlist(sqlist head){// 创建单向非循环链表
sqlist p=head->next;
while(p!=NULL){
printf("%d",p->data);
p=p->next;}
printf("\n");
}

void freelist(sqlist head){//释放链表
sqlist p,q;
p=head;
q=p->next;
while(q!=NULL){
q=p;
q=q->next;
free(p);}
free(head);
}

int main(){
int n;
sqlist head;
scanf("%d",&n);
head=creatlist(5);
printlist(head);
freelist(head);
return 0;
}


  • 写回答

1条回答

  • 浅草夏洛洛 2019-04-20 23:03
    关注

    创建单项链表for循环有问题
    修改了下

    sqlist creatlist(int n)//尾插法创建有头结点的单向链表
    {
        sqlist head, p, q;
        head = (sqlist)malloc(sizeof(struct node));
        p = head;
        for(int i = 0;i < n; i++)
        {
            q = (sqlist)malloc(sizeof(struct node));
            q->data = i;
            p->next = q;
            p = q;
        }
        p->next=NULL;
        return head;
    }
    

    还有就是释放内存那

    void freelist(sqlist head)
    {//释放链表
        sqlist p,q;
        p = head;
        while(q!=NULL)
        {
            p = q;
            q = p->next;
            free(p);
        }
    }
    
    
    评论

报告相同问题?

悬赏问题

  • ¥100 求数学坐标画圆以及直线的算法
  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决