- 浏览: 202004 次
- 性别:
- 来自: 武汉
文章分类
- 全部博客 (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)
题意:给出一个长度为n的数列,你每一次可以随意交换其中两个数字的位置。问你至少交换几次,才能使得这个数列是个单调递增数列。
思路:逆序数。归并排序求逆序数:
归并排序主要是二路归并排序,采用分治的思想:对于某个数组a[n]排序,先将前半部分排序,再将后半部分排序,最后归并两部分。归并排序是一种稳定的排序方式,且时间复杂度为O(n*log2n)。归并排序还可以求一串数中的逆序数。在归并相邻的两个有序子数组:
XlowXlow+1Xlow+2...Xmid和Ymid+1Y2Y3Y4..Yhigh的过程中,令i=low,j=mid+1,其中:Xi<Xi+1,Yi<Yi+1。若在某此比较a[i]与a[j]时,发现a[i]>a[j],说明a[i]与a[j]是一对逆序数,并且a[i+1],a[i+2],...,a[mid]都是大于等于a[i],说明a[i+1]与a[j],a[i+2]与a[j],...,a[mid]与a[j]都是逆序对。因此,逆序对应该加上mid-i+1。 poj 2299代码如下: #include <iostream>
const int MAX = 500000;
int a[MAX];
int swap[MAX]; //临时数组
int n; //数组a的长度
__int64 result; //数组a中的逆序数
//归并两个已经有序的段:a[low]—a[mid]和a[mid+1]—a[high],使得a[low]—a[high]有序。
void merge(int low, int mid, int high)
{
int i = low;
int j = mid + 1;
int m = 0;
while(i <= mid && j <= high)
{
if(a[i] <= a[j])
{
swap[m++] = a[i];
i++;
}
else
{
swap[m++] = a[j];
j++;
result += mid - i + 1;
}
}
while(i <= mid)
{
swap[m++] = a[i];
i++;
}
while(j <= mid)
{
swap[m++] = a[j];
j++;
}
for(i = 0; i < m; i++)
a[low + i] = swap[i];
}
//归并排序:对a[low]—a[high]进行归并排序。
void mergeSort(int low, int high)
{
int mid;
if(low < high)
{
mid = (low + high) /2;
mergeSort(low, mid);
mergeSort(mid + 1, high);
merge(low, mid, high);
}
}
int main()
{
int i;
while(true)
{
scanf("%d",&n);
if(n == 0) break;
result = 0;
for(i = 0; i < n; i++)
scanf("%d",a+i);
mergeSort(0, n-1);
printf("%I64d\n",result);
}
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对他家族的关系:“父 ...
相关推荐
【标题】"POJ2299-Ultra-QuickSort"是北京大学在线判题系统POJ上的一道编程题目,其主要涉及的算法是快速排序(Ultra-QuickSort)。快速排序是一种高效的排序算法,由C.A.R. Hoare在1960年提出。它的基本思想是采用...
在这里要用到__int64,也就是long long int
* 排序:例如 poj2388、poj2299。 * 简单并查集的应用。 * 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 *...
- 排序算法:如快速排序和归并排序,用于对数据进行排序,如`poj2388, poj2299`。 - 并查集:用于处理集合的合并和查询操作,如`poj3349, poj3274`。 - 哈希表:用于高效的数据查找,如`poj2151, poj1840`。 - ...
- **例题**:poj2388, poj2299 - **解释**:字符串问题通常涉及字符串的模式匹配、编辑距离等问题。 #### 3. 哈希表 - **例题**:poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503 - **解释**:哈希表是一种...
- (poj2388, poj2299):介绍二叉树、平衡二叉树等。 3. **字符串处理**: - (poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503):字符串操作算法,如哈希函数的使用、模式匹配算法等。 4. **集合和映射**...
poj1035、poj3080等训练了串的操作,poj2388、poj2299等则涉及排序问题,poj2524、poj1611等是并查集的实例,poj3349、poj3274等展示了哈希表和二分查找,poj3253是哈夫曼树的题目,poj2442和poj1442则关于堆。...
- 推荐题目:[poj2388](https://vjudge.net/problem/POJ-2388)、[poj2299](https://vjudge.net/problem/POJ-2299) - 并查集用于处理不相交集合的合并及查询问题。 3. **哈希表** - 推荐题目:[poj3349]...
2. **堆**:堆排序及其在优先队列中的应用(poj2388, poj2299)。 3. **哈希表**:用于快速查找和存储,如Hash函数的设计(poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503)。 4. **字符串处理**:Trie树...
- poj2299 - poj3232 - poj3233 - poj1064 - poj2255 - **应用场景**:适用于可以被分解为子问题的复杂问题,如快速排序、归并排序、汉诺塔问题等。 **4. 递推** - **定义**:递推是指根据已知的基础情况和...
- **示例题目**: poj2388, poj2299 #### 3. 字典树 - **内容**: 字典树是一种高效的数据结构,主要用于存储字符串集合。 - **示例题目**: poj2513 - **知识点**: - **字典树的特点**:节省空间;查询速度快;方便...
+ poj2388, poj2299 * 简单并查集的应用 * 哈希表和二分查找等高效查找法 + poj3349, poj3274, poj2151, poj1840, poj2002, poj2503 * 哈夫曼树:poj3253 * 堆 * Trie树:静态建树、动态建树 + poj2513 四、简单...
- 排序:快速排序、归并排序和堆排序,如POJ2299。 - 并查集:处理不相交集合问题,如POJ3349。 - 哈希表和二分查找:提高查找效率,如POJ2151。 - 哈夫曼树:用于数据压缩,如POJ3253。 - 堆:如POJ2299。 - ...
例如,POJ1035和POJ3080是串的经典例题,而POJ2388和POJ2299则是排序算法的代表题。 在简单搜索部分,涵盖了深度优先搜索和广度优先搜索两种搜索算法。例如,POJ2488和POJ3083是深度优先搜索的经典例题,而POJ3278...
2. 排序:快速排序、归并排序、堆排序,如poj2299。 3. 并查集:解决集合合并与查询问题,如poj3026。 4. 哈希表和二分查找:高效查找,如poj3274。 5. 哈夫曼树:用于压缩数据,如poj3253。 6. 堆:如poj2299中的堆...
2. 排序:快速排序、归并排序(涉及逆序数)和堆排序,如poj2388、poj2299。 3. 并查集:处理集合合并与查询,如poj3349。 4. 哈希表和二分查找:快速查找,如poj3274、poj2151等。 5. 哈夫曼树:用于压缩编码,如...
排序算法如快排、归并排和堆排,例如 poj2388 和 poj2299。哈希表和二分查找在 poj3349 等题目中体现其效率。trie 树在 poj2513 中有应用。 搜索策略包括深度优先搜索(DFS)和广度优先搜索(BFS),如 poj2488 和 ...
poj1035、poj3080和poj1936是关于串的问题,poj2388和poj2299则是排序算法的实践,poj3349和poj3274则涉及哈希表和二分查找,而poj3253则考察哈夫曼树的构建。 四、简单搜索 搜索算法通常分为深度优先搜索(DFS)和...
- 示例题目:poj2388, poj2299 3. **字典树(Trie)** - 字典树是一种高效的数据结构,用于存储大量字符串。 - 示例题目:poj2513 4. **哈希表** - **散列表的应用**:常用于快速查找、插入和删除操作。 - ...