- 浏览: 202012 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (137)
- c++ (74)
- c++,算法,回溯 (2)
- DP问题。 (9)
- DP问题,0/1背包问题 (3)
- 数学问题 (6)
- 贪心算法 (10)
- 排序 (16)
- 数据结构 (7)
- 容器 (2)
- 模拟问题 (2)
- 水题 (8)
- 并查集 (3)
- 非技术 (2)
- 素数问题 (1)
- DFS (3)
- 二叉树 (1)
- 递归 (1)
- 图论 (5)
- 最小生成树 (5)
- 最短路径 (6)
- bell_flaod算法 (2)
- hash (3)
- 二分查找 (1)
- 搜索 (5)
- BFS (5)
- STL (3)
- 字符串hash (1)
- 拓扑排序 (1)
- 字典树 (4)
- 哈弗曼树 (1)
- KMP (7)
- 线段树 (9)
- 树状数组 (6)
- 全排列 (2)
- DP问题 (2)
- LCS (1)
- 最长不下降子序列 (2)
- 面试经验 (3)
排序分为以下几大类:a:插入排序;b:选择排序;c:交换排序;d:归并排序;e:基数排序。
a:插入排序:分为直接插入排序与希尔排序。直接插入排序的思想是:每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。第一趟比较前两个数,然后把第二个数按大小插入到有序表中; 第二趟把第三个数据与前两个数从前向后扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。直接插入排序属于稳定的排序,时间复杂性为o(n^2),空间复杂度为O(1)。
poj 2388代码:
#include <iostream> using namespace std; const int Max=10002; void InsertSort(int a[],int n) { int i,j; int temp; for (i=0;i<n-1;i++) { temp=a[i+1]; j=i; while (j>-1&&temp<a[j]) { a[j+1]=a[j]; j--; } a[j+1]=temp; } } int main() { int n; cin>>n; int b[Max]; for(int k=0;k<n;k++) cin>>b[k]; InsertSort(b,n); cout<<b[n/2]<<endl; return 0; }
b:选择排序
在选择排序中,有一种简单的方法叫做直接选择排序,直接选择排序的基本思想是:从待排序的数据元素中选取关键字最小的数据元素并将它与第一个数据交换位置;接着从不包括第一个位置的数据元素集合中选取关键字最小的,与第二个位置的数据交换,如此重复,直到只剩一个数据元素为止。显然,这种排序方式的时间复杂度为O(n*n)。
poj 2388代码如下:
#include <iostream> using namespace std; const int Max=10002; void SelectSort(int a[],int n) { int i,j,small; int temp; for (i=0;i<n-1;i++) { small=i; for (j=i+1;j<n;j++) if(a[j]<a[small]) small=j; if(small!=i) { temp=a[i]; a[i]=a[small]; a[small]=temp; } } } int main() { int n; cin>>n; int b[Max]; for (int k=0;k<n;k++) cin>>b[k]; SelectSort(b,n); cout<<b[n/2]<<endl; return 0; }
在直接选择排序中,待排序的数据元素集合构成一个线性表,要从有n个数据元素的线性表中选择出一个最小的数据元素需要比较n-1次。如果能把待排序的数据元素集合构成一棵完全二叉树结构,则每次选择出一个最大(最小)的元素只需要比较log2n次,所以排序的时间复杂度就是O(n*log2n),这就是堆排序的思想。
堆排序的流程:
1.将完全二叉树调整为一个最大(小)堆。
从第一个非叶子结点开始到根节点,每次都将当前结点调整为一个最大堆,前提是当前结点的左孩子和右孩子都已经是最大堆。
2.每次把堆顶与当前最大堆的最后一个元素交换,最大堆元素个数减1,若此时根节点不满足最大堆的定义,调整根节点使之满足最大堆的定义。
poj 2388代码如下:
//堆排序:基于完全二叉树,是一种选择排序,不稳定。 #include <iostream> const int MAX = 100001; int a[MAX]; //调整非叶子结点a[h]使之满足最大堆的定义。前提:它的左孩子a[2*h+1]和右孩子a[2*h+2]均已是最大堆。 void createHeap(int n, int h) { int i = h; int j = 2*i + 1; int t = a[i]; bool flag = false; while(j < n && !flag) { if(j < n-1 && a[j] < a[j+1]) j++; if(t > a[j]) flag = true; else { a[i] = a[j]; i = j; j = 2*i + 1; } } a[i] = t; } //从第一个非叶子结点a[(n-1)/2]开始到a[0],构造最大堆。 void initialHeap(int n) { for(int i = (n-1)/2; i>=0; i--) createHeap(n, i); } //每次将当前最大堆的堆顶a[0](最大)与最后一个元素交换。 void heapSort(int n) { int t; initialHeap(n); for(int i = n-1; i > 0; i--) { t = a[0]; a[0] = a[i]; a[i] = t; createHeap(i,0); } } int main() { int n; scanf("%d",&n); for(int i = 0; i < n; i++) scanf("%d",&a[i]); heapSort(n); printf("%d",a[n/2]); return 0; }
c:交换排序 交换排序中的冒泡排序思想:依次比较相邻的两个数,如果a[i]>a[i+1],就把i和i+1交换位置。这样,第一遍时,最大的数就排在了最后,如此反复,就可以排序。
冒泡排序的优化:可以设置一个标志位,如果某一次循环中发现位置都没有变化,显然数组已排好序,直接退出。冒泡排序的时间复杂度为O(n*n)冒泡排序代码比较简单,
poj 2388代码如下:
快速排序是一种二叉树结构的交换排序方式。快速排序的思想:每次循环结束后,一反面将标准元素(通常为a[low])放在了未来排好序的数组中的正确位置,另一方面将数组中的元素分为了两个子数组,位于标准元素左边的关键字均小于它,位于关键元素右边的关键字均大于等于它,然后对这两个子数组分别进行同样的操作,直到low=high结束。 快速排序最坏的情况是数组已完全有序,此时二叉树将退化为单分支二叉树,深度为n。但它的平均时间复杂度为O(n*log2n),不是一种稳定的排序方法。poj 2388代码如下:#include <iostream>
using namespace std;
const int Max=10002;
void BubbleSort(int a[],int n)
{
int i,j;
int temp;
for (i=1;i<n;i++)
{
for (j=0;j<n-i;j++)
{
if (a[j]>a[j+1])
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}
}
}
int main()
{
int n;
cin>>n;
int b[Max];
for(int k=0;k<n;k++)
cin>>b[k];
BubbleSort(b,n);
cout<<b[n/2]<<endl;
return 0;
}
#include <iostream> using namespace std; const int Max=10002; void QuickSort(int a[],int low,int high) { int i,j; if(low>high) return; i=low; j=high; int temp; temp=a[i]; while (i<j) { while(i<j&&temp<a[j])j--; if (i<j) { a[i]=a[j]; i++; } while(i<j&&a[i]<temp)i++; if(i<j) { a[j]=a[i]; j--; } } a[i]=temp; QuickSort(a,low,--j); QuickSort(a,++i,high); } int main() { int n; int b[Max]; cin>>n; for (int k=0;k<n;k++) cin>>b[k]; QuickSort(b,0,n-1); cout<<b[n/2]<<endl; return 0; }
关于归并排序,以后再进行详细解释!!
发表评论
-
虚函数、纯虚函数、虚基类、抽象类、虚函数继承、虚继承
2013-08-29 14:34 836虚函数:虚函数是C++中用于实现多态(polymorphis ... -
排序算法总结
2013-05-17 11:00 841选择排序、快速排序、希尔排序、堆排序不是稳定的排序算法, ... -
poj 3122
2012-12-11 19:51 866题意:作者要开一个生日party,他现在拥有n块高度都为1 ... -
poj 3273
2012-12-11 16:49 982题意:给你天数n,和每天需要花的钱,让你把这些天分成m份(每份 ... -
字典树学习材料
2012-05-30 14:29 967字典树,又称单词查找树,Trie树,是一种树形结构,典型应 ... -
poj 1159
2012-05-28 19:08 1441题目大意:给你一段字符串,让你求出在中间最少加入几个字符 ... -
poj 3176
2012-05-28 14:47 1016大致题意: 输入一个n层的三角形,第i层有i个数,求从第 ... -
poj 1260
2012-05-28 09:54 1610题意解释: 有n个等级的珠宝,等级依次升高,等级越高价钱越高 ... -
poj 1836
2012-05-28 09:22 2710是POJ2533的扩展题。题意不难,令到原队列 ... -
poj 2533
2012-05-26 15:36 1269在做这道题目之前,首先让我们了解一下什么是LIS算法,LIS俗 ... -
poj 3267
2012-05-26 09:43 801从程序可以看出,第i个位置到L所删除的字符数,总是先取最坏情况 ... -
poj 1276
2012-05-25 16:20 2392题意: 这道题的意思是给你一堆钱,各种面值的都有,比 ... -
poj 1094
2012-05-25 13:54 1107题意:给出字母个数,和有限个有序对(a<b)求出能确定字 ... -
poj 3393
2012-05-23 17:00 1256大致题意: 科普文一篇,文章80%都是无用信息,因为 ... -
poj 3007
2012-05-14 10:21 991大致题意: 给定一个字符串,从任意位置把它切为两半, ... -
poj 3096
2012-05-10 21:09 1003题意: 定义D-pairs表示取字符串s中相距为D的两个字母 ... -
poj 1426
2012-04-26 20:11 2170大致题意: 给出一个整数n,(1 <= n <= ... -
poj 1797
2012-04-24 15:05 1623题目大意是就是何处一个图,n个顶点和m条边,每个边都有最大承载 ... -
poj 1338
2012-04-23 10:20 1257题意:题目意思是求由2,3,5的乘积组成的数从大到小排列,从1 ... -
poj 2021
2012-04-19 15:00 948题意:Ted今年100岁,给出n对他家族的关系:“父 ...
相关推荐
数据结构-排序课件,严蔚敏课本课件,比较好用
数据结构--快速排序C++源代码,自己编写调试,代码简单易懂,不长
在IT领域,算法和数据结构是基础且至关重要的部分,它们是解决问题的关键工具。本压缩包文件中的内容涉及“LUT算法”、“排序重构问题”和“教学学计划编制问题”,这些都是计算机科学教育中常见的实践课题。让我们...
"数据结构--排序--思维导图" 数据结构中排序是指将一组无序的记录序列按照一定的规则排列成有序的序列,排序的目的是为了提高数据的存储和检索效率。排序算法的稳定性是指在排序过程中,如果待排序表中有两个元素Ri...
数据结构-排序.pdf
计算机专业 上机报告 数据结构上机报告-----排序
数据结构- C语言 -排序.md
数据结构-排序(包括常用的插入排序,选择排序,冒泡排序等)
### 数据结构-排序算法的实现知识点详解 #### 实验背景及目标 本次实验的主要目的是让学生深入理解并掌握几种常见的排序算法及其应用场景。通过动手实践,不仅能够加深对各种排序算法工作原理的理解,还能够培养...
数据结构中的排序是计算机科学中一个基础且重要的概念,它涉及到如何有效地组织和处理大量数据。排序算法的主要目标是将一组无序的数据元素按照特定的标准(通常是升序或降序)排列成一个有序序列。本篇文章主要介绍...
一、实验目的 1、掌握排序的不同方法,并能用高级语言实现排序算法 二、实验内容 1、实现希尔排序算法。
总之,这个项目提供了对基础算法和数据结构的实战练习,涵盖了排序算法的性能分析和实际问题的解决,对于提升编程思维和问题解决技巧有着积极的作用。通过深入研究和实施,可以加深对这些概念的理解,并为未来更复杂...
以上是数据结构中关于排序的一些基本知识,包括排序的稳定性、比较次数、内部排序和外部排序的定义,以及直接插入排序、折半插入排序、希尔排序和冒泡排序的原理和特点。这些排序算法各有优缺点,选择哪种排序算法取...
其中的数据要用随机数产生(如10000个),至少用5组不同的数据做比较,再使用各种算法对其进行排序,记录其排序时间,再汇总比较。 (3) 演示程序以人机对话的形式进行。每次测试完毕显示各种比较指标值的列表,比较...
数据结构---二叉排序树.doc
数据结构 课程设计 多种排序算法 有界面 数据结构 课程设计 多种排序算法 有界面 数据结构 课程设计 多种排序算法 有界面 数据结构 课程设计 多种排序算法 有界面 数据结构 课程设计 多种排序算法 有界面
数据结构-C语言版:DS09-排序.ppt
总的来说,这个课程设计提供了深入学习和实践数据结构的好机会,尤其是排序算法和约瑟夫环问题的解决策略。通过实际操作,你可以提高分析问题、设计算法和编写代码的能力,这对任何计算机科学专业的学生来说都是非常...
本项目聚焦于"LUT算法"(可能是指查找表Look-Up Table)与数据结构的应用,特别是针对排序算法的比较以及教学计划编制问题。以下是这些主题的详细讨论。 首先,排序算法是计算机科学中的基本操作,用于将一组数据...
利用大量且丰富的图示与范例, 详解复杂的抽象理论,从最基本的数据结构概念开始 说明,再以Java工具加以诠释阵列结构、堆栈、链表 、队列、排序、查找等重要的概念,引领读者抓住重 点轻松进入数据结构的学习领域