c语言--力扣简单题目(删除排序链表中的重复元素)讲解

题目如下:

给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。

示例 1:

输入:head = [1,1,2] 输出:[1,2]

示例 2:

输入:head = [1,1,2,3,3] 输出:[1,2,3]

提示:

链表中节点数目在范围 [0, 300] 内

-100 <= Node.val <= 100

题目数据保证链表已经按升序 排列

结构体定义:

typedef struct Node {
char val;
struct Node* next;
}Node;
typedef Node* List;

文章目录

第一部分

List head, tail;
Node* p, * p1;//p1用来删除节点
p = (Node*)malloc(sizeof(struct Node));
p1 = (Node*)malloc(sizeof(struct Node));
int ch, val;
head = p;
tail = p;
head->next = NULL;
printf("请输入链表的内容");
while ((ch = getchar()) != '\n') {
    if (ch == ' ') {
        continue;
    }
    p = (Node*)malloc(sizeof(struct Node));
    p->val = ch-48;
    tail->next = p;
    tail = p;
    tail->next = NULL;
}

第一部分进行输入。

第二部分

tail = head->next;//让tail指向存储数据的第一个节点
while (tail->next != NULL) {
    if (tail->next->val == tail->val) {
        p1 = tail->next;
        tail->next = p1->next;
        free(p1);
    }
    else {
        tail = tail->next;
    }
}
while (head->next != NULL) {
    head = head->next;
    printf("%d ", head->val);
}
return 0;

第二部分我们先让tail指针指向第一个节点,因为题目已经是按升序排序好,所以我们这里不需要进行排序,我们将当前的节点储存的值与下一个节点储存的值进行比较,如果相等,那么我们进行删除操作,如果不相等,那么我们让tail指针指向下一个节点。

当退出循环后我们再进行打印就可以了。

相关推荐
hamster202118 分钟前
力扣【1049. 最后一块石头的重量 II】Java题解(背包问题)
java·算法·leetcode
charlie1145141916 小时前
从0开始使用面对对象C语言搭建一个基于OLED的图形显示框架(基础组件实现)
c语言·驱动开发·stm32·单片机·oled·面对对象
十月旧城14 小时前
51单片机入门_02_C语言基础0102
c语言·嵌入式硬件·51单片机
CodeWizard~16 小时前
原码、反码、补码以及lowbit运算
c语言·开发语言·c++·算法
Icomi_17 小时前
【PyTorch】6.张量运算函数:一键开启!PyTorch 张量函数的宝藏工厂
c语言·c++·人工智能·pytorch·python·深度学习·机器学习
笑口常开xpr17 小时前
C语言 --- 循环(1)
c语言·开发语言
软工在逃男大学生18 小时前
8642 快速排序
c语言·数据结构·c++·算法
最后一个bug18 小时前
linux的/proc 和 /sys目录差异
linux·c语言·arm开发·单片机·嵌入式硬件
冠位观测者20 小时前
【Leetcode 每日一题 - 补卡】219. 存在重复元素 II
数据结构·算法·leetcode
因兹菜20 小时前
[LeetCode]day6 59.螺旋矩阵2
算法·leetcode·矩阵