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

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;
}
相关推荐
liu****1 分钟前
10.指针详解(六)
c语言·开发语言·数据结构·c++·算法
CQ_YM1 分钟前
数据结构概念与顺序表
数据结构·算法·线性表
资深web全栈开发1 小时前
LeetCode 3623. 统计梯形的数目 I
算法·leetcode·职场和发展·组合数学
Jay20021112 小时前
【机器学习】23-25 决策树 & 树集成
算法·决策树·机器学习
dragoooon342 小时前
[优选算法专题九.链表 ——NO.53~54合并 K 个升序链表、 K 个一组翻转链表]
数据结构·算法·链表
xlq223228 小时前
22.多态(上)
开发语言·c++·算法
666HZ6668 小时前
C语言——高精度加法
c语言·开发语言·算法
sweet丶8 小时前
iOS MMKV原理整理总结:比UserDefaults快100倍的存储方案是如何炼成的?
算法·架构
云里雾里!9 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
CoderYanger10 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节