栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

B - 程序设计:轻重搭配

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

B - 程序设计:轻重搭配

样例:

输入样例:
6
1 9 7 3 5 5
输出样例:
4

思路:

利用快排先将输入的体重按从小到大的顺序排列好,然后在分为两部分,从最右边和中间依次想成比较,算出需要多少张票

代码实现:
#include 
#include 
#define MAX 500005

int n,i,j;
int a[MAX];
void quicksort(int left, int right){
	int temp,t;   //temp变量是基准,t变量是用来交换的第三变量 
	if(left>right){
		return;
	}
	temp = a[left];   //此时选用的是第一个数当做基准 
	i = left;     //i是1 
	j = right;     //j是n 
	while(i != j) {
		while(a[j]>=temp&&i= 1 && r >= n/2){ //结束循环的条件 
		if(2*a[m]<=a[r]){  //判断是否大于二倍 
			sum+=1;  //满足的次数 
			m--; //依次往前一个一个算 
			r--;
		}else{
			m--;  //如果不满足,则中间的一直往前寻找 
		}
	}
	printf("%d",n-sum);  //最后总共的票数 
	return 0;
}
运行结果:

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/648924.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号