14-数据结构-有序链表排序

2023-11-18

问题:

给你一个链表,然后去进行排序,并输出。

思路:

  1. 排序时,类似于冒泡排序。这里则定义两个链表指针,一个指向第一位,一个指向第一位的后一位。
  2. 由于需要排序的是数据,因此定义一个中间变量 int temp,用于后面的数据域比较排序
  3. 两层循环,外循环是指向第一位的指针,每次遍历,都会给一个数,于后面的进行比较,外循环遍历开始时,先让第二位的指针,指向第一位的后方。随后进入第二层循环,该层就是进行交换操作了,操作完后,内循环指针后移,让另一个数与外循环的那一个数比较,直到遍历结束,跳到外循环,此时外循环指针也后移,换下一个数与内循环的数字比较,

代码如下:

#include <stdio.h>
#include <malloc.h>
//单链表的应用
typedef struct lnode
{
	int data;
	lnode *next;
}lnode,*linklist;
bool inilist(linklist &l)
{
	if(l==NULL)
	return false;
	
	l->next=NULL;
	return true;
}
linklist creatlist(linklist &l)
{
	l=(linklist)malloc(sizeof(lnode));
	l->next=NULL;
	lnode *s;
	int x;
	printf("请输入需要添加值\n");
	scanf("%d",&x);
	while(x!=9999)
	{
		s=(lnode *)malloc(sizeof(lnode));
		s->data=x;
		s->next=l->next;
		l->next=s;
		printf("请再次输入下一个数据,直到输入9999为止\n");
		scanf("%d",&x);
	}
	return l;
}

void paixulist(linklist &l)
{
	
	linklist p=l->next;	//第一个指针指向第一个位置 
	linklist q=NULL;  	//第二个指针指向第一个指针的后继 
	int temp=0;   		//用来交换数据的中间变量 
	while(p!=NULL)		//当第一个结点不为空时 ,开始遍历第一个数,从第一个数进行比较 
	{	q=p->next;		//q指向第一个结点的后继结点 
		while(q!=NULL)	//拿外循环的那个数字,与其后面的数字挨个遍历,直到q遍历完 
		{
		
			if(q->data < p->data)//数据域比较 ,从而交换 
			{
				temp=p->data;
				p->data=q->data;
				q->data=temp;	
			}
			q=q->next;//第一个数与第二个数比较结束,开始q指针往后移,开始第一个数与第三个数比较。 
		}
		p=p->next;   //第一个数与其他数比较完毕,p指针后移,开始下个数字,与后面的挨个比较 
	}
	
	
}
void printlist(linklist &l)
{
	
	lnode *p=l->next;
	while(p!=NULL)
	{
		printf("%d ",p->data);
		p=p->next;
	}
	printf("\n");
	
}
   
 
int main()
{
	linklist l;
//	inilist(l);
	l=creatlist(l);
	printlist(l);
	paixulist(l);
	//pansheng(l);
	printlist(l);
	return 0;
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

14-数据结构-有序链表排序 的相关文章

随机推荐

  • 四十六.冒泡排序C语言实现

    include
  • SeleniumLibrary4.5.0 关键字详解(七)

    SeleniumLibrary4 5 0 关键字详解 七 库版本 4 5 0 库范围 全局 命名参数 受支持 简介 SeleniumLibrary是Robot Framework的Web测试库 本文档说明了如何使用SeleniumLibra
  • FbxSDK使用总结

    Fbx文件结构太复杂 FbxSDK太难理解 Fbx官网文档功能介绍太不清晰 FbxSDK中的示例程序太冷门 太不解决问题 网络上找不到能够解决我的痛点的方法 有相同烦恼的不只我一个人 一个叫 Tianyu Lang 的歪果仁也发出抱怨 并怒
  • 常见芯片算力对比(一)

    常见芯片算力对比 一 Hi3559A 即Hi3559ARFCV100 4T算力 封装 FC BGA 常备 Hi3519A Hi3519ARFVV100 才是AI芯片 2T算力 kirin980 4 2TOPS kirin990 10T算力
  • 性能测试与压力测试

    一 性能测试指软件运行的各方面指标 百度百科定义 性能测试 是通过自动化的测试工具模拟多种正常 峰值以及异常负载条件来对系统的各项性能指标进行测试 多用户并发性能测试 负载测试 强度测试 容量测试是性能测试领域里的几个方面 其实压力测试也属
  • Ubuntu16.04 安装 Anaconda

    前言 对于我这个新手来说 安装Pandas以及其余的NumPy 和SciPy等工具包可能会有点困难 最简单的方法不是直接安装Pandas 而是安装Python和构成SciPy数据科学技术栈的最流行的工具包 IPython NumPy Mat
  • 【排错】-vSphere with Tanzu - SupervisorControlPlaneVM 卡在 NotReady 状态

    故障 最近机房意外断电 导致所有虚拟机关机 等来电之后 开启了所有虚拟机 业务均恢复正常 奇怪的是 Tanzu Workload Management Supervisor 集群 的状态为NotReady 导致部分业务pod不能正常访问 如
  • 【数据库系统概论】第十章、十一章:数据库恢复技术、并发控制

    文章目录 第十章 数据库恢复技术 事务 故障 恢复技术 恢复策略 第十一章 并发控制 并发带来的问题和解决 死锁和活锁 可串行性 封锁的粒度 第十章 数据库恢复技术 事务 事务的四大特性 ACID A 原子性 要么全做 要么全不做 C 一致
  • 100天精通Python(爬虫篇)——第45天:lxml库与Xpath提取网页数据(基础+代码实战)

    文章目录 一 爬虫提取网页数据的流程图 二 lxml库 1 下载安装 2 解析HTML网页 三 Xpath介绍 1 选取节点 2 谓语 3 选取未知节点 4 选取若干路径 5 Chrome插件 XPath Helper安装使用 6 Xpat
  • Java代码大全(持续更)

    学生管理系统 简易版本 稍后博主会发出进阶版的 希望大家喜欢 package student public class Student private String id private String name private int ag
  • C++复制构造函数和赋值符的区别

    今天做C primer的习题 被复制构造函数和赋值符的区别弄晕了 简单地说 有一道题目如下描述 class t1 class t2 t1 我先看见有一个等号 以为就是赋值符来做的 其实并不是这样的 做一个实验好了 class CTest p
  • 基于Jfinal实现的权限管理系统 JfinalUIB

    JfinalUIB 是 Jfinal charisma beetl postgresql 同时支持MySQL ehcache ztree druid bcprov 实现的用户权限管理系统 项目用到了众多的开源组件 还有一些是分享的学习代码片
  • nginx 交叉编译

    环境 Linux CentOS6 9 2 6 32 696 el6 x86 64 软件版本 nginx http nginx org download nginx 1 18 0 tar gz openssl https www openss
  • python3读取excel文件只提取某些行某些列的值

    今天有一位同学给了我一个excel文件 要求读取某些行 某些列 然后我试着做了一个demo 这里分享出来 希望能帮到大家 首先安装xlrd pip3 install xlrd 然后上代码 import numpy as np import
  • Java面向对象 - 文件类

    文章目录 第4关 图片查看器 挑战任务 答案 第4关 图片查看器 挑战任务 本关任务 小明想要开发一个图片查看器 但是他想只显示文件夹下所有图片类型的文件 你来帮小明实现这个功能吧 答案 代码如下 示例 package step4 impo
  • Shell if 条件判断

    Shell 语言中的if条件 一 if的基本语法 if command then 符合该条件执行的语句 elif command then 符合该条件执行的语句 else 符合该条件执行的语句 fi 二 文件 文件夹 目录 判断 b FIL
  • systemd和initd添加开机自启服务

    一 systemd Systemd 就是为了解决这些问题而诞生的 它的设计目标是 为系统的启动和管理提供一套完整的解决方案 使用了 Systemd 就不需要再用init了 Systemd 取代了initd 成为系统的第一个进程 PID 等于
  • LitJson的使用教程

    下载LitJson dll 放进你的工程 序列化 public static void SaveData string FileName Assets Data Archice json StreamReader reader File O
  • 开发日志:微信公众号网页开发的调试工具

    在这里记录一下开发时有用到的一些工具 VConcole调试工具 手机端的H5调试工具 http debugx5 qq com
  • 14-数据结构-有序链表排序

    问题 给你一个链表 然后去进行排序 并输出 思路 排序时 类似于冒泡排序 这里则定义两个链表指针 一个指向第一位 一个指向第一位的后一位 由于需要排序的是数据 因此定义一个中间变量 int temp 用于后面的数据域比较排序 两层循环 外循