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

法一:修改指针指向

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;
		}
	}
}
相关推荐
流年如夢10 小时前
排序算法详解
数据结构·算法·排序算法
z2005093011 小时前
今日算法(二叉树)
数据结构·c++·算法
故事和你9111 小时前
洛谷-【图论2-2】最短路1
开发语言·数据结构·c++·算法·动态规划·图论
Simple-Soft11 小时前
指针的高级应用与技巧 - C语言的灵魂
c语言·数据结构·算法
Controller-Inversion12 小时前
23. 合并 K 个升序链表
数据结构·链表
Mr_pyx12 小时前
面试题记录
jvm·数据结构·算法·spring·mybatis
努力努力再努力wz12 小时前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui
iiiiyu13 小时前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
YuanDaima204813 小时前
贪心算法基础原理与题目说明
数据结构·人工智能·python·算法·贪心算法·手撕代码