实验11-2-3 逆序数据建立链表 (20 分)

实验11-2-3 逆序数据建立链表 (20 分)

本题要求实现一个函数,按输入数据的逆序建立一个链表。

函数接口定义:
struct ListNode *createlist();

函数createlist利用scanf从输入中获取一系列正整数,当读到−1时表示输入结束。按输入数据的逆序建立一个链表,并返回链表头指针。链表节点结构定义如下:

struct ListNode {

int data;

struct ListNode *next;

};

裁判测试程序样例:

#include <stdio.h>

#include <stdlib.h>

struct ListNode {

int data;

struct ListNode *next;

};

struct ListNode *createlist();

int main()

{

struct ListNode *p, *head = NULL;

复制代码
head = createlist();
for ( p = head; p != NULL; p = p->next )
    printf("%d ", p->data);
printf("\n");

return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

1 2 3 4 5 6 7 -1

输出样例:

7 6 5 4 3 2 1

复制代码
struct ListNode *createlist()
{
  int num;
  struct ListNode *ptr=NULL,*head=NULL,*tail=NULL;
  scanf("%d",&num);
  while(num!=-1)
  {
    ptr=(struct ListNode *)malloc(sizeof(struct ListNode));
    ptr->data=num;
    ptr->next=head;
    head=ptr;
    scanf("%d",&num);
  }
  return head;
} 
相关推荐
一叶落4383 小时前
题目:15. 三数之和
c语言·数据结构·算法·leetcode
y = xⁿ4 小时前
【LeetCodehot100】2:两数相加 19 删除链表倒数第n个节点
数据结构·链表
罗湖老棍子5 小时前
【例 1】数列操作(信息学奥赛一本通- P1535)
数据结构·算法·树状数组·单点修改 区间查询
big_rabbit05025 小时前
[算法][力扣222]完全二叉树的节点个数
数据结构·算法·leetcode
x_xbx6 小时前
LeetCode:206. 反转链表
算法·leetcode·链表
abant26 小时前
leetcode 138 复制随机链表
算法·leetcode·链表
ab1515177 小时前
3.17二刷基础112 118 完成进阶52
数据结构·算法
美式请加冰7 小时前
链表的介绍和使用
数据结构·链表
小王不爱笑1328 小时前
排序算法 Java
数据结构·算法·排序算法
不想看见4048 小时前
Power of Four二进制特性--力扣101算法题解笔记
数据结构·算法