贪心算法(算法竞赛、蓝桥杯)--奶牛晒衣服

1、B站视频链接:A28 贪心算法 P1843 奶牛晒衣服_哔哩哔哩_bilibili

题目链接:奶牛晒衣服 - 洛谷

cpp 复制代码
#include <bits/stdc++.h> 
using namespace std;
priority_queue<int> q;//用大根堆维护湿度的最大值 
int n,a,b;
int tim,maxn;

int main(){
	scanf("%d%d%d",&n,&a,&b);
	for(int i=1;i<=n;i++){
		int x;
		scanf("%d",&x);
		q.push(x);
	}
	//每次找出剩余的湿度最大的衣服,使用烘干机
	maxn=q.top();
	q.pop();
	while(maxn>tim*a){//对于最大值大于自然条件时则用烘干机 
		tim++;
		maxn-=b;
		q.push(maxn);
		maxn=q.top();
		q.pop();
	}
	//对于其他不是最大值的就能在自然条件下烘干 
	printf("%d",tim); 
	return 0;
}
cpp 复制代码
#include <bits/stdc++.h> 
using namespace std;
int n,a,b,w[500005];

bool check(int t){
	int s=0;
	for(int i=1;i<=n;i++){
		if(w[i]<=t*a)continue;//自然条件下能烘干 
		s+=(w[i]-t*a+b-1)/b;
	}
	return s<=t;
}

int main(){
	ios::sync_with_stdio(0);
  	cin>>n>>a>>b;
  	for(int i=1;i<=n;i++) cin>>w[i];
  	//二分法找时间 
  	int l=0,r=1e6,mid;
  	while(l+1<r){
  		mid=l+r>>1;
		  check(mid)?r=mid:l=mid;	
	}
	cout<<r;
	return 0;
}
相关推荐
LYFlied9 小时前
【每日算法】LeetCode 153. 寻找旋转排序数组中的最小值
数据结构·算法·leetcode·面试·职场和发展
唐装鼠9 小时前
rust自动调用Deref(deepseek)
开发语言·算法·rust
ytttr87310 小时前
MATLAB基于LDA的人脸识别算法实现(ORL数据库)
数据库·算法·matlab
jianfeng_zhu12 小时前
整数数组匹配
数据结构·c++·算法
smj2302_7968265212 小时前
解决leetcode第3782题交替删除操作后最后剩下的整数
python·算法·leetcode
LYFlied13 小时前
【每日算法】LeetCode 136. 只出现一次的数字
前端·算法·leetcode·面试·职场和发展
唯唯qwe-13 小时前
Day23:动态规划 | 爬楼梯,不同路径,拆分
算法·leetcode·动态规划
做科研的周师兄13 小时前
中国土壤有机质数据集
人工智能·算法·机器学习·分类·数据挖掘
来深圳14 小时前
leetcode 739. 每日温度
java·算法·leetcode
yaoh.wang14 小时前
力扣(LeetCode) 104: 二叉树的最大深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽