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

法一:修改指针指向

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;
		}
	}
}
相关推荐
郝YH是人间理想33 分钟前
Pandas库DataFrame数据结构
数据结构·pandas
像污秽一样1 小时前
算法与设计与分析-习题4.1
算法·链表·排序算法
j_xxx404_1 小时前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久1 小时前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构
We་ct2 小时前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
Aaswk3 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
Yvonne爱编码3 小时前
JAVA数据结构 DAY7-二叉树
java·开发语言·数据结构
总斯霖4 小时前
P15445永远在一起!题解(月赛T2)
数据结构·c++·算法·深度优先
像污秽一样4 小时前
算法设计与分析-习题4.5
数据结构·算法·排序算法·剪枝
样例过了就是过了4 小时前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs