sdut pta 链表3(优化)-----7-3 sdut-C语言实验-链表的结点插入

简介: sdut pta 链表3(优化)-----7-3 sdut-C语言实验-链表的结点插入

7-3 sdut-C语言实验-链表的结点插入


分数 20


全屏浏览


切换布局


作者 马新娟


单位 山东理工大学


给出一个只有头指针的链表和 n 次操作,每次操作为在链表的第 m 个元素后面插入一个新元素x。若m 大于链表的元素总数则将x放在链表的最后。


输入格式:

多组输入。每组数据首先输入一个整数n(n∈[1,100]),代表有n次操作。

接下来的n行,每行有两个整数Mi(Mi∈[0,10000]),Xi。

输出格式:

对于每组数据。从前到后输出链表的所有元素,两个元素之间用空格隔开。


输入样例:

1. 4
2. 1 1
3. 1 2
4. 0 3
5. 100 4

输出样例:

3 1 2 4


代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

栈限制

8192 KB

#include <stdio.h>
#include <stdlib.h>
struct node
{
    int a;
    struct node *next;
};//定义结构体类型;
int main()
{
    struct node *head,*p;
    int n,i;
    int x;
    while(~scanf("%d",&n))
    {
        head = (struct node*)malloc(sizeof(struct node));
        //要多组输入,每一组输入都要重新开辟一个头结点;
        head -> next = NULL;
        for(i=0; i<n; i++)
        {
 
            p = (struct node*)malloc(sizeof(struct node));
            p -> next = NULL;
            scanf("%d%d",&x,&p -> a);
            struct node *q = head -> next;
            struct node *qi = head;//定义两个游动指针
            while(q&&x--)//寻找插入的位置;
            {
                q = q -> next;
                qi = qi -> next;
            }
            qi -> next = p;
            p -> next = q;//插入节点;
 
        }
        struct node *p;
    p = head -> next;
    while(p)
    {
        if(p -> next)
        {
            printf("%d ",p -> a);
        }
        else printf("%d\n",p -> a);
        p = p -> next;
    }
    }
 
    return 0;
}


#include <stdio.h> #include <stdlib.h>


这两行代码包含了标准的输入输出库和标准库,后者提供了动态内存分配的功能。


struct node { int a; struct node *next; };//定义结构体类型;


定义了一个名为node的结构体,它包含一个整型数据a和一个指向同类型结构体的指针next。这个结构体用于表示链表中的每个节点。


int main() { // ... }


定义了main函数,程序的执行从这里开始。


struct node *head, *p; int n, i; int x;


声明了头节点指针head,新节点指针p,循环计数器n和i,以及用于临时存储输入值的x。


while(~scanf("%d",&n)) { // ... }


使用while循环读取每组输入的整数数量n,直到输入失败(例如文件结束EOF)。~scanf是一种技巧,用于检查scanf是否成功读取了输入。


head = (struct node*)malloc(sizeof(struct node)); head->next = NULL;


为链表的头节点分配内存,并初始化头节点的next指针为NULL。


for(i = 0; i < n; i++) { // ... }


循环n次,每次读取一对整数。


p = (struct node*)malloc(sizeof(struct node)); scanf("%d%d", &x, &p->a);


为新节点分配内存,并读取一个整数到x,然后将p->a设置为读取的值。


struct node *q = head->next; struct node *qi = head; while(q && x--) { // ... }


这段代码试图通过x--来寻找插入新节点的位置,


qi->next = p; p->next = q;


将新节点p插入到链表中qi节点的后面。


p = head->next; while(p) { // ... }


遍历链表并打印所有节点的数据。


return 0; }


main函数返回0,表示程序正常结束。


目录
相关文章
|
1月前
|
存储 算法 Perl
数据结构实验之链表
本实验旨在掌握线性表中元素的前驱、后续概念及链表的建立、插入、删除等算法,并分析时间复杂度,理解链表特点。实验内容包括循环链表应用(约瑟夫回环问题)、删除单链表中重复节点及双向循环链表的设计与实现。通过编程实践,加深对链表数据结构的理解和应用能力。
55 4
|
2月前
|
算法
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
76 1
|
1月前
|
存储 算法 搜索推荐
链表的中间结点
【10月更文挑战第24天】链表的中间结点是链表操作中的一个重要概念,通过快慢指针法等方法可以高效地找到它。中间结点在数据分割、平衡检测、算法应用等方面都有着重要的意义。在实际编程中,理解和掌握寻找中间结点的方法对于解决链表相关问题具有重要价值。
21 1
|
3月前
链表的中间结点
链表的中间结点
182 57
|
2月前
【LeetCode 09】19 删除链表的倒数第 N 个结点
【LeetCode 09】19 删除链表的倒数第 N 个结点
18 0
|
4月前
|
算法
LeetCode第19题删除链表的倒数第 N 个结点
该文章介绍了 LeetCode 第 19 题删除链表的倒数第 N 个结点的解法,通过使用快慢双指针,先将快指针移动 n 步,然后快慢指针一起遍历,直到快指针到达链尾,从而找到倒数第 N 个结点的前一个结点进行删除,同时总结了快慢指针可减少链表遍历次数的特点。
LeetCode第19题删除链表的倒数第 N 个结点
|
5月前
【数据结构OJ题】链表中倒数第k个结点
牛客题目——链表中倒数第k个结点
40 1
【数据结构OJ题】链表中倒数第k个结点
|
4月前
|
存储 Java 开发者
揭秘!HashMap底层结构大起底:从数组到链表,再到红黑树,Java性能优化的秘密武器!
【8月更文挑战第24天】HashMap是Java集合框架中的核心组件,以其高效的键值对存储和快速访问能力广受开发者欢迎。在JDK 1.8及以后版本中,HashMap采用了数组+链表+红黑树的混合结构,实现了高性能的同时解决了哈希冲突问题。数组作为基石确保了快速定位;链表则用于处理哈希冲突;而当链表长度达到一定阈值时,通过转换为红黑树进一步提升性能。此外,HashMap还具备动态扩容机制,当负载因子超过预设值时自动扩大容量并重新哈希,确保整体性能。通过对HashMap底层结构的深入了解,我们可以更好地利用其优势解决实际开发中的问题。
123 0
|
4月前
【刷题记录】链表的中间结点
【刷题记录】链表的中间结点
|
5月前
【数据结构OJ题】链表的中间结点
力扣题目——链表的中间结点
28 0
【数据结构OJ题】链表的中间结点