用c实现的各种排序的方法
#include <stdio.h> void swap(int *a, int *b);
void bubble_sort(int a[], int n);
void select_sort(int a[], int n);
void insert_sort(int a[], int n);
void shell_sort(int a[], int n);
void heap_adjust(int a[], int i, int n);
void heap_sort(int a[], int n);
void quick_sort(int a[], int low, int high); int main()
{
// int arr[] = {0,2,3,1,6,9,8,7,4,5};
int arr[1000];
int n,m;
printf("请输入你排序的数字个数:\n");
scanf("%d",&n);
printf("请输入你排序的%d个数字:\n",n);
for(int i=0;i<n;i++)
scanf("%d",&arr[i]);
printf("请输入你所使用的排序方法(数字):\n1 冒泡排序\n2 选择排序\n3 插入排序\n4 希尔排序\n5 堆排序\n6 高速排序\n");
scanf("%d",&m);
switch(m){
case 1:
bubble_sort(arr, n);
break;
case 2:
select_sort(arr, n);
break;
case 3:
insert_sort(arr, n);
break;
case 4:
shell_sort(arr, n);
break;
case 5:
heap_sort(arr, n);
break;
case 6:
quick_sort(arr, 0, n-1);
break;
} for (int i = 0; i < n; i++)
{
printf("%d\n", arr[i]);
} return 0;
} //交換數據
void swap(int *a, int *b)
{
int tmp = *a;
*a = *b;
*b = tmp;
} //冒泡排序法
//時間複雜度O(n^2) 空間複雜度O(1)
void bubble_sort(int a[], int n)
{
int i, j;
//旗幟位。判斷這次遍歷是否有交換
int flag = 1; for (i = 0; i < n && flag; i++)
{
flag = 0;
for (j = n-2 ; j >= i; j--)
{
if (a[j] > a[j+1])
{
swap(&a[j], &a[j+1]);
flag = 1;
}
}
}
} //簡單選擇排序
//時間複雜度O(n^2) 空間複雜度O(1)
void select_sort(int a[], int n)
{
int i, j, min; for (i = 0; i < n ; i++)
{
min = i;
for (j = i+1; j < n; j++)
{
if (a[j] < a[min])
{
min = j;
}
}
if (min != i)
{
swap(&a[min], &a[i]);
}
}
} //直接插入排序
//時間複雜度O(n^2) 空間複雜度O(1)
void insert_sort(int a[], int n)
{
for (int i = 0; i < n ; i++)
{
int temp = a[i];
int j = i-1;
while (j>=0 && a[j] > temp)
{
a[j+1] = a[j];
j--;
}
a[j+1] = temp;
}
} //希爾排序
//時間複雜度為O(nlogn) 空間複雜度為O(1)
void shell_sort(int a[], int n)
{
int i,j,temp;
int gap = 0;
while (gap <= n) gap = gap*3+1;
while (gap > 0)
{
for (i = gap; i < n; i++)
{
temp = a[i];
j = i - gap;
while (j >= 0 && a[j] > temp)
{
a[j+gap] = a[j];
j = j - gap;
}
a[j+gap] = temp;
}
gap = (gap-1)/3;
}
} //堆排序
//時間複雜度為O(nlogn) 空間複雜度為O(1)
void heap_sort(int a[], int n)
{
for (int i = n/2 - 1; i >= 0; i--)
{
heap_adjust(a, i, n);
}
for (int i = n-1; i > 0; i--)
{
swap(&a[0], &a[i]); heap_adjust(a, 0, i);
}
} //構建大頂堆
void heap_adjust(int a[], int i, int n)
{
int child, temp; for (temp = a[i]; 2*i+1 < n; i = child)
{
child = 2*i+1;
//取得較大子結點索引
if (child < n -1 && a[child] < a[child+1]) child++;
//保證父結點大於等於子結點
if (temp < a[child]) swap(&a[i], &a[child]);
else break;
}
} //高速排序
//時間複雜度為O(nlogn) 空間複雜度為O(logn) ~ O(n)
void quick_sort(int a[], int low, int high)
{
int i = low+1;
int j = high;
int key = a[low]; if (low >= high) return; while (1) {
while (key<a[j]) j--;
while (key>a[i] && i<j) i++;
if (i >= j) break; swap(&a[i], &a[j]); if (a[i] == key) j--;
else i++;
} swap(&a[low], &a[j]); if (i-1>low) quick_sort(a, low, i-1);
if (j+1<high) quick_sort(a, j+1, high);
}
用c实现的各种排序的方法的更多相关文章
- discuz x2 个人资料项排序问题解决方法、添加自定义字段、修改栏目名称和介绍
第一次写文章,希望与人提供方便同时,别误人子弟,自己研究的,大家看不懂只改文件就可以了,如果发现不对的地方请回复或直接通知我,谢谢,本来想在discuz论坛上发的,不懂版规也没时间看版规,怕发错,隔小 ...
- Oracle中中文、数字,英文混杂形式的字段进行排序的方法
http://blog.csdn.net/p451933505/article/details/9272257 对Oracle中中文.数字.英文混杂形式的字段进行排序的方法: 例如: order by ...
- 编写一个类,其中包含一个排序的方法Sort(),当传入的是一串整数,就按照从小到大的顺序输出,如果传入的是一个字符串,就将字符串反序输出。
namespace test2 { class Program { /// <summary> /// 编写一个类,其中包含一个排序的方法Sort(),当传入的是一串整数,就按照从小到大的 ...
- erlang下lists模块sort(排序)方法源码解析(二)
上接erlang下lists模块sort(排序)方法源码解析(一),到目前为止,list列表已经被分割成N个列表,而且每个列表的元素是有序的(从大到小) 下面我们重点来看看mergel和rmergel ...
- erlang下lists模块sort(排序)方法源码解析(一)
排序算法一直是各种语言最简单也是最复杂的算法,例如十大经典排序算法(动图演示)里面讲的那样 第一次看lists的sort方法的时候,蒙了,几百行的代码,我心想要这么复杂么(因为C语言的冒泡排序我记得不 ...
- js按照特定的中文字进行排序的方法
之前遇到过按照中文字符排序的需求很顺利的解决了,这次是按照特定的中文字进行排序,比如按照保守型,稳健型,平衡型,成长型,进取型进行排序. 可以使用localeCompare() 方法来实现中文按照拼音 ...
- 数组升序排序的方法Arrays.sort();的应用
package com.Summer_0421.cn; import java.util.Arrays; /** * @author Summer * 数组升序排序的方法Arrays.sort();应 ...
- python中的list按照某一列进行排序的方法
如题,python中的list着实很好用,我有如下一个list 可以看出list中的每一个元素是由字符串,两个新的list,以及一个float组成,现在想根据这最后一个float对这个list进行排序 ...
- Python字典按值排序的方法
Python字典按值排序的方法: 法1: (默认升序排序,加 reverse = True 指定为降序排序) # sorted的结果是一个list dic1SortList = sorted( di ...
- Excel VBA解读(54):排序——Sort方法
Excel VBA解读(54):排序——Sort方法 看看下面的Excel界面截图,“排序”和“筛选”往往在一起,这大概是很多数据需要先排序后筛选吧 首先以“性别”作为排序字段,升序排列,并且第一行 ...
随机推荐
- Python正则表达式初识(一)
首先跟大家简单唠叨两句为什么要学习正则表达式,为什么在网络爬虫的时候离不开正则表达式.正则表达式在处理字符串的时候扮演着非常重要的角色,在网络爬虫的时候也十分常用,大家可以把它学的简单一些,但是不能不 ...
- 织梦DedeCMS判断简略标题为空时则显示完整标题
使用织梦DedeCMS系统程序开发网站中,我们会遇到很多因网页版面设计限定的宽度,使文章标题需要进行字数限制,通常做法是在a标签中加入一个title属性,让鼠标放上去的时候显示完整标题.但是标题被剪裁 ...
- 学习《人工智能一种现代的方法(第3版)》中文PDF+英文PDF
学习人工智能概论时,推荐看看<人工智能:一种现代的方法(第3版)>,最权威.最经典的人工智能教材,已被全世界100多个国家的1200多所大学用作教材. 全面性以及结构的安排还是不错的,值得 ...
- 00075_BigInteger
1.Java中long型为最大整数类型,对于超过long型的数据如何去表示呢.在Java的世界中,超过long型的整数已经不能被称为整数了,它们被封装成BigInteger对象.在BigInteger ...
- Maven学习总结(20)——Maven pom.xml配置再体会
Maven的pom.xml配置文件详解 <!--父项目的坐标.如果项目中没有规定某个元素的值,那么父项目中的对应值即为项目的默认值. 坐标包括group ID,artifact ID和 vers ...
- Mysql学习总结(11)——MySql存储过程与函数
摘要:存储过程和函数是在数据库中定义一些SQL语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的SQL语句.存储过程和函数可以避免开发人员重复的编写相同的SQL语句.而且,存储过程和函数是在 ...
- hiho week 38 P1 : 二分·二分答案
P1 : 二分·二分答案 Time Limit:10000ms Case Time Limit:1000ms Memory Limit:256MB 描述 在上一回和上上回里我们知道Nettle在玩&l ...
- HDU——T 1506 Largest Rectangle in a Histogram|| POJ——T 2559 Largest Rectangle in a Histogram
http://acm.hdu.edu.cn/showproblem.php?pid=1506 || http://poj.org/problem?id=2559 Time Limit: 2000/1 ...
- hdoj-1016-Prime Ring Problem【深搜】
Prime Ring Problem Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- Kinect 开发 —— 录音
不涉及语音识别~~ <Window x:Class="KinectRecordAudio.MainWindow" xmlns="http://schemas.mic ...