删除单链表中最小的数

以C语言为例:

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

struct chain {
	int data;
	struct chain *next;
} *head;

chain *createchain() {
	struct chain *p = (struct chain *)malloc(sizeof(chain));
	p->next = NULL;
	return p;
}

首先建立一个链表,并且对其初始化,接下来就是要删除单链表最小的数,分两步:
1、找到单链表最小的表元

2、删除单链表中最小的表元

在第一步,找表元时,我们需要特别注意的是首表元的判断。首表元之前不再有前驱表元,因此无法纳入其他表元的判断过程之中。应该单独判断首表元是否为最小表元。首表元不是最小表元时,找出最小表元的前驱表元。

在第二步,删除最小表元。如果首表元为最小:则head=head->next;  若首表元不为最小,首先我们通过第一步找到了前驱表元Pmin,接下来,我们想要删除Pmin->next,只需要                    Pmin->next = Pmin->next->next;   

void delmin(chain *L) {
	chain *Pmin = L, *s = L;
// 若链表为空,不执行任何操作
	if (L->next == NULL)
		return;
//首先判断首元素是否为最小,如果是最小直接删除并return
	while (s) {
		if (s->data < Pmin->data)
			Pmin = s;
		s = s->next;
	}
	if (Pmin == head) {
		head = head->next;
		return;
	}
/* 如果首元素不是最小,继而判断后面的元素。删除表元之后的某个表元:
必须要知道该表元的前驱表元指针,因此我们的判断条件与首表元判断有区别
下面这一块,找到最小元的前驱表元即为Pmin*/
	Pmin = L, s = L->next;
	while (s->next != NULL) {
		if (s->next->data < Pmin->next->data)
			Pmin = s;
		s = s->next;
	}
//找到Pmin之后,进行删除操作
	Pmin->next = Pmin->next->next;
	free(s);
}

 建立主函数,取最小数量,3个表元来验证结果是否正确。通过分别取三个元素为最小进行判断。验证结果正确。

int main() {
	head = createchain();
	head->next = createchain();
	head->next->next = createchain();

	head->data = 18;
	head->next->data = 19;
	head->next->next->data = 15;

	printf("%d %d %d\n", head->data, head->next->data, head->next->next->data);
	delmin(head);

	while (head) {
		printf("%d  ", head->data);
		head = head->next;
	}

	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蓝天1010

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值