数据结构:链表的冒泡排序

法一:修改指针指向

cs 复制代码
//法二
void maopao_link(link_p H){
	if(H==NULL){
		printf("头节点为空\n");
		return;
	}
	if(link_empty(H)){
		printf("链表为空\n");
		return;
	}
	link_p tail=NULL;
	while(H->next->next!=tail){
		link_p p=H;
		link_p q=H->next;
		while(q->next!=tail){
			if((q->data)>(q->next->data)){
				p->next=q->next;
				q->next=q->next->next;
				p->next->next=q;
				q=p->next;
			}
			q=q->next;
			p=p->next;
		}
		tail=q;//每轮循环确定一个最大的元素放在最后,然后就不用比了
		      //每轮都可以少比一个
	}
}

法二:交换数值,不修改指针

cs 复制代码
void maopao_data(link_p H){
	if(H==NULL){
		printf("头节点为空\n");
		return;
	}
	if(link_empty(H)){
		printf("链表为空\n");
		return;
	}
	int temp;
	for(int i=0;i<H->len;i++){
		link_p p=H->next;

		for(int j=0;j<H->len-i;j++){
			if(p->data>p->next->data){
				temp=p->data;
				p->data=p->next->data;
				p->next->data=temp;
			}
			p=p->next;
		}
	}
}
相关推荐
AC赳赳老秦18 分钟前
2026 智能制造趋势:DeepSeek 助力“黑灯”工厂运营,实现生产流程自动化
网络·数据结构·算法·安全·web安全·prometheus·deepseek
程序员酥皮蛋24 分钟前
hot 100 第三十题 30. 两两交换链表中的节点
数据结构·算法·leetcode·链表
ShineWinsu1 小时前
对于C++中list的详细介绍
开发语言·数据结构·c++·算法·面试·stl·list
冬夜戏雪1 小时前
Leetcode 颠倒二进制位/二进制求和
java·数据结构·算法
俩娃妈教编程1 小时前
2023 年 09 月 二级真题(1)--小杨的 X 字矩阵
数据结构·c++·算法·双层循环
烟花落o2 小时前
【数据结构系列02】轮转数组、返回倒数第k个节点
数据结构·算法·leetcode·刷题
Bear on Toilet3 小时前
递归_二叉树_48 . 二叉树最近公共祖先查找
数据结构·算法·二叉树·dfs
9359610 小时前
机考27 翻译21 单词14
c语言·数据结构·算法
Renhao-Wan13 小时前
Java 算法实践(四):链表核心题型
java·数据结构·算法·链表
好学且牛逼的马14 小时前
【Hot100|25-LeetCode 142. 环形链表 II - 完整解法详解】
算法·leetcode·链表