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

法一:修改指针指向

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;
		}
	}
}
相关推荐
ygklwyf21 小时前
模拟退火算法零基础快速入门
数据结构·c++·算法·模拟退火算法
寄存器漫游者1 天前
数据结构 二叉树与哈希表
数据结构·散列表
Sayuanni%31 天前
数据结构_Map和Set
java·数据结构
执着2591 天前
力扣hot100 - 144、二叉树的前序遍历
数据结构·算法·leetcode
近津薪荼1 天前
递归专题(4)——两两交换链表中的节点
数据结构·c++·学习·算法·链表
散峰而望1 天前
【算法竞赛】树
java·数据结构·c++·算法·leetcode·贪心算法·推荐算法
鱼很腾apoc1 天前
【实战篇】 第14期 算法竞赛_数据结构超详解(下)
c语言·开发语言·数据结构·学习·算法·青少年编程
近津薪荼1 天前
递归专题(3)——反转链表
数据结构·c++·学习·算法·链表
senijusene1 天前
数据结构与算法:完全二叉树和非完全二叉数的各种详细操作以及哈希表的简单应用
数据结构·算法·链表
季明洵1 天前
反转字符串、反转字符串II、反转字符串中的单词
java·数据结构·算法·leetcode·字符串