`

poj 2388

 
阅读更多

 题意大概是农场主要找出体重处于中间的母牛,实际上是要求在规定时间内给出一组数据的中间数,说白了,就是各种排序,数据的个数是奇数,n/2正好处于中间,可以用STL模板,也可以不用,代码分别如下:

代码一:不用STL模板。自己写的快速排序:

#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;
}

 

代码二:使用STL模板:

#include <iostream>
using namespace std;
int cmp(const void *a,const void *b)
{
	return *(int*)a-*(int*)b;
}
int main()
{
	int n;
	while (cin>>n)
	{
		int a[100001];
		memset(a,0,sizeof(a));
		for (int i=0;i<n;i++)
		{
			cin>>a[i];
		}
		qsort(a,n,sizeof(a[0]),cmp);
		cout<<a[n/2]<<endl;
	}
	return 0;
}

 

第三个版本如下:

#include <iostream>
#include <stdio.h>
#include <algorithm>
#include <vector>
using namespace std;
int main()
{
	int n, m;
    scanf( "%d", &n );
    m = n;
    vector<int> milk;
    int temp;
    while ( m > 0 )
    {
        scanf( "%d", &temp );
        milk.push_back( temp );
        
        -- m;  
    }
    sort( milk.begin(), milk.end() );
    printf( "%d/n", milk[ milk.size()/2 ] );
    system("pause");
    return 1;
}

 

水题一个主要考查对排序算法的理解……

 

分享到:
评论

相关推荐

    POJ2388-Who's in the Middle

    《POJ2388-Who's in the Middle》是一个典型的计算机编程竞赛题目,主要考察参赛者的算法设计和实现能力。这个题目源自北京大学的在线评测系统POJ(PKU Online Judge),是编程爱好者和学生提升编程技能的重要平台之...

    直接插入排序练习:POJ 2388

    这个练习题目,"POJ 2388",显然是通过编程实现直接插入排序来解决一个特定的问题。在这个问题中,我们需要理解直接插入排序的机制,并能用Java语言编写出高效的代码。 直接插入排序的基本步骤如下: 1. 从第二个...

    堆排序练习:POJ 2388

    标题“堆排序练习:POJ 2388”指的是一个关于使用堆排序算法解决编程竞赛问题的实践案例。在编程竞赛中,如POJ(Programming Online Judge)平台上的问题2388,参赛者经常需要高效地解决排序问题,而堆排序作为一种...

    poj题目分类

    * 排序:例如 poj2388、poj2299。 * 简单并查集的应用。 * 哈希表和二分查找等高效查找法:例如 poj3349、poj3274、poj2151、poj1840、poj2002、poj2503。 * 哈夫曼树:例如 poj3253。 * 堆:例如 poj2513。 *...

    poj训练计划.doc

    - 排序算法:如快速排序和归并排序,用于对数据进行排序,如`poj2388, poj2299`。 - 并查集:用于处理集合的合并和查询操作,如`poj3349, poj3274`。 - 哈希表:用于高效的数据查找,如`poj2151, poj1840`。 - ...

    POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类POJ分类

    - **例题**:poj2388, poj2299 - **解释**:字符串问题通常涉及字符串的模式匹配、编辑距离等问题。 #### 3. 哈希表 - **例题**:poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503 - **解释**:哈希表是一种...

    poj各种分类

    快速排序、归并排序和堆排序等,不仅用于排序,也常用于解决与逆序数相关的问题,如poj2388。 #### 并查集 用于处理集合的合并与查询操作,如poj3349所示。 #### 哈希表 高效查找数据的工具,利用哈希函数将数据...

    POJ题目简单分类(ACM)

    - **排序算法**:包括快速排序、归并排序和堆排序,如poj2388,优化查找效率。 - **并查集**:用于处理集合合并与查询问题。 - **哈希表和二分查找**:提高查找效率,如poj3349,用于快速定位元素。 - **哈夫曼...

    acm训练计划(poj的题)

    - (poj2388, poj2299):介绍二叉树、平衡二叉树等。 3. **字符串处理**: - (poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503):字符串操作算法,如哈希函数的使用、模式匹配算法等。 4. **集合和映射**...

    acm poj300题分层训练

    poj1035、poj3080等训练了串的操作,poj2388、poj2299等则涉及排序问题,poj2524、poj1611等是并查集的实例,poj3349、poj3274等展示了哈希表和二分查找,poj3253是哈夫曼树的题目,poj2442和poj1442则关于堆。...

    acm新手刷题攻略之poj

    - 推荐题目:[poj2388](https://vjudge.net/problem/POJ-2388)、[poj2299](https://vjudge.net/problem/POJ-2299) - 并查集用于处理不相交集合的合并及查询问题。 3. **哈希表** - 推荐题目:[poj3349]...

    ACM-POJ 算法训练指南

    2. **堆**:堆排序及其在优先队列中的应用(poj2388, poj2299)。 3. **哈希表**:用于快速查找和存储,如Hash函数的设计(poj3349, poj3274, POJ2151, poj1840, poj2002, poj2503)。 4. **字符串处理**:Trie树...

    POJ 分类题目

    - poj2388 - poj2299 - **应用场景**:适用于数据组织和分析。 **3. 并查集** - **定义**:一种用于处理一些不交集的合并及查询问题的数据结构。 - **示例题目**: - poj1703 - poj1988 - poj2524 - poj2492 ...

    强大的POJ分类——各类编程简单题及其算法分类

    2. **排序**:包括快速排序、归并排序(涉及逆序数)、堆排序,如POJ2388、2299。 3. **并查集**:处理集合合并和查询问题。 4. **哈希表** 和 **二分查找**:提供高效查找能力,如POJ3349、3274、2151、1840、2002...

    POJ题目分类

    - **示例题目**: poj2388, poj2299 #### 3. 字典树 - **内容**: 字典树是一种高效的数据结构,主要用于存储字符串集合。 - **示例题目**: poj2513 - **知识点**: - **字典树的特点**:节省空间;查询速度快;方便...

    ACM常用算法及其相应的练习题.docx

    + poj2388, poj2299 * 简单并查集的应用 * 哈希表和二分查找等高效查找法 + poj3349, poj3274, poj2151, poj1840, poj2002, poj2503 * 哈夫曼树:poj3253 * 堆 * Trie树:静态建树、动态建树 + poj2513 四、简单...

    ACM 详解算法目录

    例如,POJ1035和POJ3080是串的经典例题,而POJ2388和POJ2299则是排序算法的代表题。 在简单搜索部分,涵盖了深度优先搜索和广度优先搜索两种搜索算法。例如,POJ2488和POJ3083是深度优先搜索的经典例题,而POJ3278...

    ACM算法总结大全——超有用!

    2. 排序:快速排序、归并排序(涉及逆序数)和堆排序,如poj2388、poj2299。 3. 并查集:处理集合合并与查询,如poj3349。 4. 哈希表和二分查找:快速查找,如poj3274、poj2151等。 5. 哈夫曼树:用于压缩编码,如...

    很快速的提高算法能力.pdf

    排序算法如快排、归并排和堆排,例如 poj2388 和 poj2299。哈希表和二分查找在 poj3349 等题目中体现其效率。trie 树在 poj2513 中有应用。 搜索策略包括深度优先搜索(DFS)和广度优先搜索(BFS),如 poj2488 和 ...

Global site tag (gtag.js) - Google Analytics