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指针指向下一个节点。

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

相关推荐
8Qi826 分钟前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS1 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源
社交怪人2 小时前
【范围判断】信息学奥赛一本通C语言解法(题号2052)
c语言
Lsk_Smion2 小时前
力扣实训 _ [200].岛屿数量
算法·leetcode·深度优先
LONGZETECH4 小时前
软硬协同+故障注入:无人机仿真维修与操控仿真底层算法逻辑拆解
大数据·c语言·算法·3d·unity·无人机
Lsk_Smion4 小时前
力扣实训 _ [543].二叉树的直径 _ [23].合并K个升序列表
数据结构·算法·leetcode
zlinear数据采集卡4 小时前
SPI Flash存储电路深度解析:从芯片选型到ZLinear采集卡的实战设计
c语言·嵌入式硬件·自动化·硬件架构
凯瑟琳.奥古斯特4 小时前
力扣1235:加权区间调度最优解
java·python·算法·leetcode·职场和发展
memcpy06 小时前
LeetCode 2144. 打折购买糖果的最小开销【贪心】
算法·leetcode·职场和发展
散峰而望7 小时前
【算法练习】算法练习精选:陶陶摘苹果(基础+升级)、Music Notes、字串变换,你能AC几道?
数据结构·c++·算法·leetcode·贪心算法·github·动态规划