鱼C论坛

 找回密码
 立即注册
查看: 1021|回复: 6

[已解决]求助大佬C语言单链表按位置修改操作

[复制链接]
发表于 2022-1-1 12:39:38 | 显示全部楼层 |阅读模式

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

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

x
单链表按位置修改操作,已知一个带头结点的单链表中包含5个结点,每个结点包含两个域,一个域为数据域(整型数据),另一个域为指针域,5个结点的数据域分别为22,7,45,89,78,从键盘输入两个整数,第一个整数为要修改的数据的位置,第二整数为修改后的数。输出前5个数(每个输出的数之间用一个空格隔开,最前面没有空格,最后有一个空格)。
输入示例:2 88
输出示例:22 88 45 89 78
  1. #include<stdio.h>
  2. #include<malloc.h>
  3. typedef struct LNode{
  4. int data;
  5. struct LNode* next;
  6. }LNode,*LinkList;
  7. int main(){
  8. int arr[]= {22,7,45,89,78};
  9. int n = 5,pos,x,j;
  10. LinkList rear,p,q;
  11. //尾插法创建链表 P是链表长度
  12. LinkList head =
  13. (LinkList)malloc(sizeof(LNode));
  14. head->next = NULL;
  15. rear = head;
  16. for(int i=0;i<n;i++){
  17. p = (LinkList)malloc(sizeof(LNode));
  18. p->data = arr[i];
  19. p->next = NULL;
  20. rear->next = p;
  21. rear = p;
  22. }
复制代码


最佳答案
2022-1-1 13:04:35
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. struct Node{
  4.     int data;
  5.     struct Node* next;
  6. };

  7. int main(){
  8.     int arr[] = {22, 7, 45, 89, 78};
  9.     struct Node *head = NULL, *tail = NULL;
  10.    
  11.     for(int i = sizeof(arr)/sizeof(int)-1; i > -1; i--){
  12.         tail = head;
  13.         head = (struct Node*)malloc(sizeof(struct Node));
  14.         head->data = arr[i];
  15.         head->next = tail;
  16.     }
  17.    
  18.     int a, b;
  19.     scanf("%d%d", &a, &b);
  20.    
  21.     struct Node *p = head;
  22.     for(int i = 0; p; i++, p = p->next) if(i+1 == a) p->data = b;
  23.    
  24.     while(head){
  25.         printf("%d ", head->data);
  26.         head = head->next;
  27.     }
  28.     return 0;
  29. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-1-1 13:04:35 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. struct Node{
  4.     int data;
  5.     struct Node* next;
  6. };

  7. int main(){
  8.     int arr[] = {22, 7, 45, 89, 78};
  9.     struct Node *head = NULL, *tail = NULL;
  10.    
  11.     for(int i = sizeof(arr)/sizeof(int)-1; i > -1; i--){
  12.         tail = head;
  13.         head = (struct Node*)malloc(sizeof(struct Node));
  14.         head->data = arr[i];
  15.         head->next = tail;
  16.     }
  17.    
  18.     int a, b;
  19.     scanf("%d%d", &a, &b);
  20.    
  21.     struct Node *p = head;
  22.     for(int i = 0; p; i++, p = p->next) if(i+1 == a) p->data = b;
  23.    
  24.     while(head){
  25.         printf("%d ", head->data);
  26.         head = head->next;
  27.     }
  28.     return 0;
  29. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-1-1 17:14:03 | 显示全部楼层

大佬, 求您解答一下单链表按位置插入操作
22,7,45,89,78
输入示例:2 88
输出示例:22 88 7 45 89"
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-1-1 17:17:13 | 显示全部楼层
mycwt60 发表于 2022-1-1 17:14
大佬, 求您解答一下单链表按位置插入操作
22,7,45,89,78
输入示例:2 88

题目要求:单链表按位置插入操作

单链表的初始数据:22 7 45 89 78
输入示例:2 88
输出示例:22 88 7 45 89

这里可以看出第 2 位置就是数字 7
把 7 换成 88 就是解答
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-1-1 17:52:02 | 显示全部楼层
傻眼貓咪 发表于 2022-1-1 17:17
题目要求:单链表按位置插入操作

单链表的初始数据:22 7 45 89 78

把第二位的7换成88,之前的第二位和后面的位 都要向后挪动一个位置 这个语法上该怎么写
  1. int temp;
  2. for(int i = 0; p; i++, p = p->next)
  3. temp=p->data;
  4. p->data = b;
  5. p->next=temp;
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-1-1 18:52:29 | 显示全部楼层
mycwt60 发表于 2022-1-1 17:52
把第二位的7换成88,之前的第二位和后面的位 都要向后挪动一个位置 这个语法上该怎么写

哦哦,我还以为你问同一题,你要的插入法:
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. struct Node{
  4.     int data;
  5.     struct Node* next;
  6. };

  7. int main(){
  8.     int arr[] = {22, 7, 45, 89, 78}, N = 5;
  9.     struct Node *head = NULL, *tail = NULL;
  10.    
  11.     for(int i = N-1; i > -1; i--){
  12.         tail = head;
  13.         head = (struct Node*)malloc(sizeof(struct Node));
  14.         head->data = arr[i];
  15.         head->next = tail;
  16.     }
  17.    
  18.     int a, b;
  19.     scanf("%d%d", &a, &b);
  20.    
  21.     struct Node *p = head;
  22.     struct Node *t = NULL;
  23.     for(int i = 0; i < N-1; i++, p = p->next)
  24.     if(i+1 == a){
  25.         t = (struct Node*)malloc(sizeof(struct Node));
  26.         t->data = p->data;
  27.         t->next = p->next;
  28.         p->data = b;
  29.         p->next = t;
  30.     }
  31.     p->next = NULL;
  32.     while(head){
  33.         printf("%d ", head->data);
  34.         head = head->next;
  35.     }
  36.     return 0;
  37. }
复制代码
输出结果:
  1. 2 88
  2. 22 88 7 45 89
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-1-1 19:31:22 | 显示全部楼层
傻眼貓咪 发表于 2022-1-1 18:52
哦哦,我还以为你问同一题,你要的插入法:输出结果:

谢谢大佬
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-25 02:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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