两个排序算法

好几天没写博客了,最近要考试了,有c语言。本来准备就为了应付考试,随便学一下的,然后准备下学期用c来学习数据结构和算法,可是,看了一些视频,就准备入坑c/c++了。。。。自己学了将近一个学期的c#,就这样放弃感觉还是有些小舍不得呢。。。不过,技术都是有共同性的,也不算是浪费时间了

然后贴代码:

 1 int num[10];
 2     time_t tms;
 3     srand((unsigned int)time(&tms));//生成种子
 4     for (int i = 0; i < 10; i++)//生成数组元素为10 的数组
 5     {
 6         num[i] = 100 + rand() % 100;
 7         printf("%d\n", num[i]);
 8     }
 9
10
11     //冒泡排序
12     for (int i = 0; i < 10 - 1; i++)
13     {
14
15         for (int j = 0; j < 10 - 1 - i; j++)
16         {
17             //int max=0;//num为下标
18             if (num[j]>num[j+1])
19             {
20                 int tmp = num[j];
21                 num[j] = num[j+1];
22                 num[j+1] = tmp;
23             }
24         }
25     }
 1 int num[10];
 2     time_t tms;
 3     srand((unsigned int)time(&tms));//生成种子
 4     for (int i = 0; i < 10; i++)//生成数组元素为10 的数组
 5     {
 6         num[i] = 100 + rand() % 100;
 7         printf("%d\n", num[i]);
 8     }
 9
10
11     //选择排序
12     for (int i = 0; i < 10; i++)
13     {
14         int max=0;//最大数的下标,开始默认为第一个数
15         for (int j = 0; j < 10  - i; j++)
16         {
17
18             if (num[max] < num[j])
19             {
20                 max = j;
21             }
22         }
23
24         int tmp = num[10 - 1 - i];
25         num[10 - 1 - i] = num[max];
26         num[max] = tmp;
27
28     }

上面就是冒泡排序和选择排序的实现代码了

冒泡排序呢,就是每一次都从头开始冒泡,选出大的那个,继续往后面冒,一轮下来,最大的就冒到最后面了,下一轮冒泡可以找到倒数第二大的数放在倒数第二的位置。。。。反复。。。。

选择排序呢,就是每一次都找出最大数的下标,然后将最大的数放到最后。

我个人认为,这两种排序方法本质上都是一样的,都是比较之后交换,冒泡交换的是数值本身,而选择交换的是数组的下标。

就纯int型数字数组来言的话,我觉得效率基本是一样的,因为数组的下标和数组中元素的sizeof都是一样的,是4个字节。

当然,这些都是我瞎想的,具体到底是怎样的,相信以后我学了数据结构和算法之后,能够得到正确的答案。

时间: 2024-10-13 07:39:38

两个排序算法的相关文章

经典的两种排序算法

一.冒泡排序 int temp = 0; for (int j = 1; j < a.Length; j++) { for (int i = 0; i < a.Length - j; i++)//内循环,每走一趟会把最小值放到最后 { if (a[i] < a[i + 1]) { temp = a[i]; a[i] = a[i + 1]; a[i + 1] = temp; } } } 二.选择法排序 int min; for (int j = 0; j< a.Length; j++

算法—比较两种排序算法:选择排序和插入排序

现在我们已经实现了两种排序算法,我们很自然地想知道选择排序和插入排序哪种更快.这里我们第一次用实践说明我们解决这个问题的办法. 性质:对于随机排序的无重复主键的数组,插入排序和选择排序的运行时间是平方级别的,两者之比应该是一个较小的常数. 例证:这个结论在过去的半个世纪中已经在许多不同类型的计算机上经过了验证.在1980年本书第一版完成之时插入排序就比选择排序快一倍,现在仍然是这样,尽管那时这些算法将10万条数据排序需要几个小时而现在只需要几秒钟.在你的计算机上插入排序也比选择排序快一些吗?可以

mysql 排序长度限制之max_length_for_sort_data以及mysql两种排序算法

SET max_length_for_sort_data = 1024 SHOW VARIABLES LIKE '%max_length_for_sort_data%'; 查询:SELECT * FROM CS_COLUMNS ORDER BY table_name,column_name LIMIT 0,100 错误代码: 1815Internal error: IDB-2015: Sorting length exceeded. Session variable max_length_for

算法(第4版)-2.1 初级排序算法

2.1.1 游戏规则 1. 排序成本模型:在研究排序算法时,我们需要计算比较和交换的数量.对于不交换元素的算法,我们会计算访问数组的次数. 2. · 原地排序算法:除了函数调用所需的栈和固定数目的实例变量之外无需额外内存的原地排序算法: · 其他排序算法:需要额外内存空间来储存另一份数组副本. 2.2.2 选择排序 public class Selection { public static void sort(Comparable[] a) { // 将a[]按升序排列 int N = a.l

数据结构精要------直接插入排序和希尔排序算法

上篇总结中主要实践了算法的内排序的选择排序,那么接下来我们继续实践插入排序排序的两种:直接插入排序和希尔排序算法. -----直接插入排序 package com.sort; /** * 直接插入排序 * * @author weixing-yang * * 算法思路: * 每步将一个待排序的元素,插入到前面已排序好的一组元素中的适当位置, * 直到所有元素全部出入完成为止. */ public class InsertionSort { public void insertionSort(in

数据结构精要------冒泡与直接排序算法

作为程序员的我们在程序开发的时候经常会用到一些简单的排序算法,例如:对数组进行快速排序:要实现这些就需要运用到数据结构排序算法的知识,那么熟练使用和掌握排序算法对于开发人员来说是百利而无一害.同时记录一下知识点也是自己对自己的进一步巩固总结: 那么何为排序算法呢? 排序是计算机内经常进行的一种操作,其目是一组 "无序 "的记录序列调整为 "有序 "的记 录序列.排序分内排序和外排序. 那么何为内排和外排呢? 内排序 :指在排序 期间数据对象全部存放在内存排序. 外排

js十大排序算法详解

十大经典算法导图  图片名词解释:n: 数据规模k:"桶"的个数In-place: 占用常数内存,不占用额外内存Out-place: 占用额外内存 1.冒泡排序 1.1  原始人冒泡排序 function bubbleSort(arr) { var len = arr.length; for (var i = 0; i < len; i++) { for (var j = 0; j < len - 1 - i; j++) { if (arr[j] > arr[j+1]

【Unity3D自学记录】可视化对照十多种排序算法(C#版)

在这篇文章中.我会向大家展示一些排序算法的可视化过程.我还写了一个工具.大家可对照查看某两种排序算法. 下载源代码 – 75.7 KB 下载演示样例 – 27.1 KB 引言 首先,我觉得是最重要的是要理解什么是"排序算法".依据维基百科.排序算法(Sorting algorithm)是一种能将一串数据按照特定排序方式进行排列的一种算法. 最经常使用到的排序方式是数值顺序以及字典顺序.有效的排序算法在一些算法(比如搜索算法与合并算法)中是重要的,如此这些算法才干得到正确解答.排序算法也

常见的五类排序算法图解和实现(多关键字排序:基数排序以及各个排序算法的总结)

基数排序思想 完全不同于以前的排序算法,可以说,基数排序也叫做多关键字排序,基数排序是一种借助“多关键字排序”的思想来实现“单关键字排序”的内部排序算法. 两种方式: 1.最高位优先,先按照最高位排成若干子序列,再对子序列按照次高位排序 2.最低位优先:不必分子序列,每次排序全体元素都参与,不比较,而是通过分配+收集的方式. 多关键字排序 例:将下表所示的学生成绩单按数学成绩的等级由高到低排序,数学成绩相同的学生再按英语成绩的高低等级排序.        第一个关键字是数学成绩,第二个关键字是英