C语言链表中数组实现数据选择排序,升序、降序功能主要难点
链表排序讲解:
head指针指向链表的头结点,是找到整个链表的唯一依据,如果head指针丢失,整个链表就找不到了。
head存储的是第一个节点的地址,head->next存储的是第二个节点的地址; 任意一个节点p的地址,只能通过它前一个节点的next来求得。
单向链表的选择排序图示: ---->[1]---->[3]---->[2]...---->[n]---->[NULL](原链表)
head 1->next 3->next 2->next n->next
选择排序(Selection sort)是一种简单直观的排序算法。
首先在未排序序列中找到最小元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小元素,然后放到排序序列末尾。以此类推,直到所有元素均排序完毕。
动画演示:http://www.nowamagic.net/librarys/veda/detail/1849
选择排序
定义的结构体
struct student { ]; //学生学号 ]; //学生姓名 struct student *next; //next 指针 指向 struct student 类型的变量 }stu;
里面的变量均为数组
那怎么实现结构体中定义(有)数组变量,链表遍历结构体,按照结构体里面变量来排序呢?
其中对数组比较大小、比较两个字符串的大小来使用的函数是: strcmp() 也就是string compare字符串比较。
对数组之间的赋值函数是 strcpy() ==="string copy"
升序:
/*************** 函数功能: 升序排列出勤学生 返回:指向链表表头的指针 /***************/ struct student *sort_message_order(struct student* head) //升序 按照ID顺序 { struct student *Back,*pointer; //p指针指向新的节点 back指针指向链表的尾节点 struct student temp; // 定义结构体student别名,typedef也可以定义的结构体别名 Back=head->next; pointer=head->next; //跳过头结点 指向下一个节点 头结点中没有学生信息 while(Back!=NULL) //如果尾节点不为空 就一直遍历下去 { while(pointer->next!=NULL) //如果指向新开辟的结点不为空就一直遍历下去 { pointer=pointer->next; //指向下一个新开辟的结点 ) //如果back->ID大于pointer->ID就返回大于0的值;后面大于前面的 往后放 { strcpy(temp.ID,Back->ID); strcpy(temp.name,Back->name); //把尾节点值赋值给临时temp结构体变量 strcpy( Back->ID,pointer->ID); strcpy(Back->name,pointer->name); //把指向的新节点 跟尾节点交换 位置 strcpy(pointer->ID,temp.ID); strcpy(pointer->name,temp.name);//将临时temp结构体变量赋值给指向的结构体变量 } } Back=Back->next; //指向下一个尾节点 pointer=Back; //指向尾节点 } return head; //返回头结点 }
降序:
/*************** 函数功能: 降序排列出勤学生 返回:指向链表表头的指针 /***************/ struct student * sort_message_Desc(struct student* head)//Descending降序 { struct student *Back,*pointer; //p总是指向新申请的结点 back总是指向链表的尾节点 struct student temp; Back=head->next; pointer=head->next;//跳过头结点,头结点中没有学生信息 while(Back!=NULL) { while(pointer->next!=NULL) { pointer=pointer->next; ) // back->ID小于pointer->ID返回负数 把最小的 往后放 降序 { strcpy(temp.ID,Back->ID); strcpy(temp.name,Back->name); //把尾节点值赋值给临时temp结构体变量 strcpy( Back->ID,pointer->ID); strcpy(Back->name,pointer->name); //指向的新节点 跟尾节点交换 位置 strcpy(pointer->ID,temp.ID); strcpy(pointer->name,temp.name); //将临时temp结构体变量赋值给指向的结构体变量 } } Back=Back->next; //指向下一个尾节点 pointer=Back; //指向尾节点 } return head; //返回头结点 }
输出打印链表内容:
void Print_List(struct student *head) { struct student* pointer; pointer=head->next; //跳过无数据的头结点 while(pointer!=NULL) { printf(" ",pointer->ID); printf(" ",pointer->name); pointer=pointer->next;//指向下一个节点 } }
C语言链表中数组实现数据选择排序,升序、降序功能主要难点的更多相关文章
- 【java】实体类中 按照特定的字段 进行升序/降序 排序
背景: 实际页面上 所有的分值都是按照JSON格式存储在一个字符串中 存储在同一个字段中: {"ownPTotal":"10>0","ownO ...
- java中的选择排序之降序排列
import java.util.Arrays;//必须加载 class Demo{ public static void main(String []args){ int[] arr={3,54,4 ...
- HTML中实现Table表头点击升序/降序排序
题目:如下图,请实现表格信息的排序功能,当点击表头的属性区域,将表格信息进行排序切换功能,即第一次点击为降序排序,再一次点击进行升序排序. 姓名 力量 敏捷 智力 德鲁伊王 17 24 13 月之骑士 ...
- C语言:将ss所指字符串中所有下标为奇数位上的字母转换成大写,若不是字母,则不转换。-删除指针p所指字符串中的所有空白字符(包括制表符,回车符,换行符)-在带头结点的单向链表中,查找数据域中值为ch的结点,找到后通过函数值返回该结点在链表中所处的顺序号,
//将ss所指字符串中所有下标为奇数位上的字母转换成大写,若不是字母,则不转换. #include <stdio.h> #include <string.h> void fun ...
- sql 中实现打乱数据的排序
sql 中实现打乱数据的排序 order by NEWID()就实现了数据的打乱
- js学习篇--数组按升序降序排列
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 现在输入 n 个数字, 以逗号, 分开; 然后可选择升或者 降序排序;
/* 现在输入 n 个数字, 以逗号, 分开: 然后可选择升或者 降序排序: */ import java.util.*; public class bycomma{ public static St ...
- java面试题:已知一个数组[2,4,6,2,1,5],将该数组进行排序(降序,不能用工具类进行排序),创建两条线程交替输出排序后的数组,线程名自定义
package com.swift; import java.util.Arrays; import java.util.Comparator; public class ArrayThread_Te ...
- c语言-链表VS数组
数组和链表的区别 数组是将元素在内存中连续存放,由于每个元素占用内存相同,可以通过下标迅速访问数组中任何元素.但是如果要在数组中增加一个元素,需要移动大量元素,在内存中空出一个元素的空间,然后将要 ...
随机推荐
- Selenium学习笔记之外部化相关测试数据---xml
我们也可以用xml来定义一个信息更为丰富的UIMap.xml文件,比如,额外还添加控件所属的页,控件的类型,然后解析构建一个XMLParser类来读取相应的值. <?xml version=&q ...
- Java final类
如果说整个类都是final(在它的定义前冠以final关键字),就表明自己不希望从这个类继承,或者不允许其他任何人采取这种操作.换言之,出于这样或那样的原因,我们的类肯定不需要进行任何改变:或者出于安 ...
- Java final数据
许多程序设计语言都有自己的办法告诉编译器某个数据是"常数".常数主要应用于下述两个方面: 1)编译期常数,它永远不会改变: 2)在运行期间初始化的一个值,我们不希望它发生变化.ss ...
- 多平台下Modbus通信协议库的设计(一)
1.背景 1.1.范围 MODBUS 是 OSI 模型第 7 层上的应用层报文传输协议, 它在连接至不同类型总线或网络的设备之间提供客户机/服务器通信. 自从 1979 年出现工业串行链路的事实标准以 ...
- JQuery强化教程 —— jQuery Easing
从jQuery API 文档中可以知道,jQuery自定义动画的函数.animate( properties [, duration] [, easing] [, complete] )有四个参数: ...
- iOS 正则 检测是否为手机号
- (BOOL)validateMobile:(NSString *)mobileNum { NSString *regex = @"^1[3|5|7|8][0-9]\\d{8}$" ...
- 27款后台管理页面设计 DIV+CSS+JS
-----------. 演示: http://www.websjy.com/club/websj ... _61040268/index.htm http://www.websjy.com/club ...
- SharePoint 2013 通过审计获取文档下载次数
1.创建一个文档库,进入库设置,找到”Information management policy settings”,点进去,如下图: 2.分别设置”Document”.”Folder”两个,如下图: ...
- 简单粗暴的对android so文件加壳,防止静态分析
转载自http://bbs.pediy.com/showthread.php?t=191649 以前一直对.so文件加载时解密不懂,不了解其工作原理和实现思路.最近翻看各种资料,有了一些思路.看到论坛 ...
- RxJava 和 RxAndroid 二(操作符的使用)
前言:对Rx不了解的朋友可以先看我的第一篇博文 RxJava 和 RxAndroid 一 (基础),是对Rxjava的基本介绍 1.merge操作符,合并观察对象 List<String> ...