洛谷 P1080 [NOIP2012 提高组] 国王游戏

一道非常有挑战性的题目(~太难了~)。

这题我们可以用贪心来做。

思路:

  1. 首先我们定义一个结构体 struct,里面放的是每个人左手和右手的数字。
  2. 接着我们需要一种排列方式,使得获得奖赏最多的大臣,所获奖赏尽可能的少;这句话听起来是不是听绕口?意思就是说得到奖赏数量最多,但加起来的总奖赏和最少;因此,我们可以定义一个自定义排序 cmp,使 a.l*a.r<b.l*b.r。
  3. 我们可以在定义两个 vector 数组 ans 和 t,ans 第 0 个值初始化成0,t 第 0 个值初始化成 1。
  4. 随后是高精度乘低精度和高精度除以低精度的函数。
  5. 最后再定义一个函数 compare,用来比较大小。
  6. 输入,注意:要先输入 f[0].l 和 f[0].r,表示国王的左手和右手。

AC CODE:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
struct stu{
	int l;
	int r;
}f[1005];
bool cmp(stu a,stu b){
	return a.l*a.r<b.l*b.r;
}
int n;
vector<int> ans(1,0);
vector<int> t(1,1);
inline vector<int> mul(vector<int> &a,int b){
	vector<int> res;
	int t = 0;
	int len = a.size();
	for(int i=0;i<len;i++){
		t+=a[i]*b;
		res.push_back(t%10);
		t/=10;
	}
	while(t){
		res.push_back(t%10);
		t/=10;
	}
	return res;
}
inline vector<int> div(vector<int> &a,int b){
	vector<int> res;
	int r = 0;
	int len = a.size();
	for(int i=len-1;i>=0;i--){
		r = 10*r+a[i];
		if(r>=b){
			res.push_back(r/b);
			r%=b;
		}else{
			res.push_back(0);
		}
	}
	vector<int> cnt;
	len = res.size();
	for(int i=len-1;i>=0;i--){
		cnt.push_back(res[i]);
	}
	while((cnt.back()==0)&&(cnt.size()>1)){
		cnt.pop_back();
	}
	return cnt;
}
inline int compare(vector<int> &a,vector<int> &b){
	int lenA = a.size();
	int lenB = b.size();
	if(lenA!=lenB){
		int t = lenA-lenB;
		return t;
	}else{
		for(int i=lenA-1;i>=0;i--){
			if(a[i]!=b[i]){
				int t = a[i]-b[i];
				return t;
			}
		}
		return 0;
	} 
}
int main(){
	cin>>n;
	cin>>f[0].l>>f[0].r;
	for(int i=1;i<=n;i++){
		cin>>f[i].l>>f[i].r;
	}
	sort(f+1,f+1+n,cmp);
	t = mul(t,f[0].l);
	for(int i=1;i<=n;i++){
		vector<int> res = div(t,f[i].r);
		if(compare(ans,res)<0){
			ans = res;
		}
		t = mul(t,f[i].l);
	}
	int len = ans.size();
	for(int i=len-1;i>=0;i--){
		cout<<ans[i];
	}
	cout<<endl;
	return 0;
}
相关推荐
铭哥的编程日记3 天前
贪心算法精选30道编程题 (附有图解和源码)
算法·贪心算法
哈泽尔都6 天前
运动控制教学——5分钟学会PRM算法!
人工智能·单片机·算法·数学建模·贪心算法·机器人·无人机
Miraitowa_cheems6 天前
LeetCode算法日记 - Day 68: 猜数字大小II、矩阵中的最长递增路径
数据结构·算法·leetcode·职场和发展·贪心算法·矩阵·深度优先
Mr.Ja8 天前
【LeetCode热题100】No.11——盛最多水的容器
算法·leetcode·贪心算法·盛水最多的容器
小邓儿◑.◑9 天前
贪心算法 | 每周8题(二)
c++·算法·贪心算法
咖啡啡不加糖9 天前
贪心算法详解与应用
java·后端·算法·贪心算法
天选之女wow10 天前
【代码随想录算法训练营——Day31】贪心算法——56.合并区间、738.单调递增的数字、968.监控二叉树
算法·leetcode·贪心算法
smallnetter10 天前
华为OD机试C卷 - 分披萨 - 贪心 DFS - (Java & C++ & JavaScript & Python)
华为od·贪心算法·dfs
天选之女wow11 天前
【代码随想录算法训练营——Day28】贪心算法——134.加油站、135.分发糖果、860.柠檬水找零、406.根据身高重建队列
算法·leetcode·贪心算法