题意:求冒泡的交换次数。
分析:求快排的逆序数。这题直接用冒泡会超时的,虽然时间有7000MS,所以选择时间效率高的归并排序。
代码:
#include<iostream>
#include<algorithm>
using namespace std;
int s[500010];
int left_t[500010];
int right_t[500010];
long long ct;
void merge(int s[],int p,int q,int r)
{
int i,j,k;
int n1=q-p+1;
int n2=r-q;
for(i=1;i<=n1;i++)
left_t[i]=s[p+i-1];
for(i=1;i<=n2;i++)
right_t[i]=s[q+i];
left_t[n1+1]=0x7fffffff;
right_t[n2+1]=0x7fffffff;
i=j=1;
for(k=p;k<=r;k++)
{
if(left_t[i]<=right_t[j])
{
s[k]=left_t[i];
i++;
}
else
{
s[k]=right_t[j];
j++;
ct+=n1-i+1;
}
}
}
void mergesort(int s[],int p,int r)
{
int q;
if(p<r)
{
q=(p+r)/2;
mergesort(s,p,q);
mergesort(s,q+1,r);
merge(s,p,q,r);
}
}
int main()
{
int n;
while(cin>>n,n)
{
ct=0;
for(int i=0;i<n;i++)
cin>>s[i];
mergesort(s,0,n-1);
cout<<ct<<endl;
}
return 0;
}
更多详细信息请查看
java教程网 http://www.itchm.com/forum-59-1.html
分享到:
相关推荐
【标题】"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`。 - ...
2. **堆**:堆排序及其在优先队列中的应用(poj2388, poj2299)。 3. **哈希表**:用于快速查找和存储,如Hash函数的设计(poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503)。 4. **字符串处理**:Trie树...
- **例题**: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]...
- 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. **哈希表** - **散列表的应用**:常用于快速查找、插入和删除操作。 - ...