问题描述 在一个整数序列A1, A2, …, An中,如果存在某个数,大于它的整数数量等于小于它的整数数量,则称其为中间数。 在一个序列中,可能存在多个下标不相同的中间数,这些中间数的值是相同的。 给定一个整数序列,请找出这个整数序列的中间数的值。 输入说明 输入的第一行包含了一个整数n,表示整数序列中数的个数,1 ≤ n ≤ 1000。 第二行包含n个正整数,依次表示A1, A2, …,An,1 ≤ Ai ≤ 1000。 输出说明 如果序列的中间数存在,则输出中间数的值,否则输出-1表示不存在中间数。 输入样例 输入样例1 6 2 6 5 6 3 5 输入样例2 4 3 4 6 7 输出样例 输出样例1 5 输出样例2 -1 样例说明 样例1中比5小的数有2个,比5大的数也有2个。因此中间数是5 样例2中4个数都不满足中间数的定义,因此中间数是-1
#由于CSDN上大部分代码不太适合初学者,故写下此篇易懂的代码
代码逻辑是循环遍历,看是否满足中间数的条件
#include<stdio.h>
int main()
{
int n,i,count1=0,count2=0,j,media=-1;
scanf("%d",&n);
int arr[1000]={0},brr[1000]={0};
for(i=0;i<n;i++)
{
scanf("%d",&arr[i]);
brr[i]=arr[i];
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
if(arr[i]==brr[j])
{
continue;
}
if(brr[j]>arr[i])
{
count1++;
}
if(brr[j]<arr[i])
{
count2++;
}
}
if(count1==count2)
{
media=arr[i];
break;
}
count1=0;
count2=0;
}
if(n==1)
{
media=-1;
}
printf("%d",media);
return 0;
}
欢迎访问我的个人博客网站Levitate Gu