鱼C论坛

 找回密码
 立即注册
查看: 1039|回复: 1

[已解决]求助大佬 单链表按位置删除操作

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

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

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

x
单链表按位置删除操作,已知一个带头结点的单链表中包含6个结点,每个结点包含两个域,一个域为数据域(整型数据),另一个域为指针域,
5个结点的数据域分别为22,7,45,89,78,15,从键盘输入一个整数,该整数为被删除数据的位置。输出前5个数
每个输出的数之间用一个空格隔开,最前面没有空格,最后有一个空格)。
输入示例:2
输出示例:22 45 89 78 15
#include<stdio.h>
#include<malloc.h>
typedef struct LNode{
int data;
struct LNode* next;
}LNode,*LinkList;
int main(){
int arr[]= {22,7,45,89,78};
int n = 5,pos,x,j;
LinkList rear,p,q;
//尾插法创建链表 P是链表长度
LinkList head = 
(LinkList)malloc(sizeof(LNode));
head->next = NULL;
rear = head;
for(int i=0;i<n;i++){
p = (LinkList)malloc(sizeof(LNode));
p->data = arr[i];
p->next = NULL;
rear->next = p;
rear = p;
} 
最佳答案
2022-1-1 13:09:42
#include <stdio.h>
#include <stdlib.h>

struct Node{
    int data;
    struct Node* next;
};

int main(){
    int arr[] = {22, 7, 45, 89, 78, 15};
    struct Node *head = NULL, *tail = NULL;
    
    for(int i = sizeof(arr)/sizeof(int)-1; i > -1; i--){
        tail = head;
        head = (struct Node*)malloc(sizeof(struct Node));
        head->data = arr[i];
        head->next = tail;
    }
    
    int a;
    scanf("%d", &a);
    
    struct Node *p = head;
    struct Node *t;
    for(int i = 0; p; i++, p = p->next)
    if(i+1 == a){
        t = p->next;
        p->data = t->data;
        p->next = t->next;
    }
    
    while(head){
        printf("%d ", head->data);
        head = head->next;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

struct Node{
    int data;
    struct Node* next;
};

int main(){
    int arr[] = {22, 7, 45, 89, 78, 15};
    struct Node *head = NULL, *tail = NULL;
    
    for(int i = sizeof(arr)/sizeof(int)-1; i > -1; i--){
        tail = head;
        head = (struct Node*)malloc(sizeof(struct Node));
        head->data = arr[i];
        head->next = tail;
    }
    
    int a;
    scanf("%d", &a);
    
    struct Node *p = head;
    struct Node *t;
    for(int i = 0; p; i++, p = p->next)
    if(i+1 == a){
        t = p->next;
        p->data = t->data;
        p->next = t->next;
    }
    
    while(head){
        printf("%d ", head->data);
        head = head->next;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-9 21:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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