CSP认证考试(第九次)第一题

试题编号:

1

试题名称:

中间数

时间限制:

10.0s

内存限制:

512.0MB

问题描述:

  在一个整数序列a1a2, …, an中,如果存在某个数,大于它的整数数量等于小于它的整数数量,则称其为中间数。在一个序列中,可能存在多个下标不相同的中间数,这些中间数的值是相同的。
  给定一个整数序列,请找出这个整数序列的中间数的值。

输入格式

  输入的第一行包含了一个整数n,表示整数序列中数的个数。
  第二行包含n个正整数,依次表示a1a2, …, an

输出格式

  如果约定序列的中间数存在,则输出中间数的值,否则输出-1表示不存在中间数。

样例输入

6
2 6 5 6 3 5

样例输出

5

样例说明

  比5小的数有2个,比5大的数也有2个。

样例输入

4
3 4 6 7

样例输出

-1

样例说明

  在序列中的4个数都不满足中间数的定义。

样例输入

5
3 4 6 6 7

样例输出

-1

样例说明

  在序列中的5个数都不满足中间数的定义。

评测用例规模与约定

  对于所有评测用例,1 ≤ n ≤ 1000,1 ≤ ai ≤ 1000。

 

自己的解题思路:

使用vector存储数据,使用sort()排序,找出排序后的中间数(n/2位置处的数),使用count函数判断中间数等值的个数

如果存在满足题意的中间数,需满足:

例如:1 2 3 4...4 5 6 7 其中4为中间数,且4的个数可以为任意(>0) 大于4和小于4的个数相等,其和偶数。所以数据总数的奇偶和4的奇偶是一样的。也就是说数据总数的奇偶和中间数个数的奇偶是一样的。

 

代码:

 1 #include<vector>
 2 #include<iostream>
 3 #include<algorithm>
 4 using namespace std;
 5 int main(){
 6     vector<int> array;
 7     int n;
 8     cin>>n;
 9     for(int i=0;i<n;i++){//输入数据
10         int temp;
11         cin>>temp;
12         array.push_back(temp);
13     }
14     vector<int> temp;
15     temp=array;
16     sort(temp.begin(),temp.end());//排序
17     //for(int i=0;i<temp.size();i++){
18 //        cout<<temp[i]<<" ";
19 //    }
20     int num=0;
21     num=count(temp.begin(),temp.end(),temp[n/2]);//判断中间数个数
22     if(num%2==0&&n%2==0||n%2==1&&num%2==1){
23         cout<<temp[n/2]<<endl;
24     }
25     else cout<<-1<<endl;
26 }

 

posted @ 2017-02-22 19:05  Elaine_DWL  阅读(727)  评论(0编辑  收藏  举报