Educational Codeforces Round 165 (Rated for Div. 2) (C、D)

1969C - Minimizing the Sum

题意:

思路:观察到操作数很小,最值问题+操作数很容易想到dp,用表示第个元素,操作了次的最小值总和,转移的时候枚举连续操作了几次即可,而连续操作了几次即将全部变成其中的最小值。

cpp 复制代码
// Problem: C. Minimizing the Sum
// Contest: Codeforces - Educational Codeforces Round 165 (Rated for Div. 2)
// URL: https://codeforces.com/contest/1969/problem/C
// Memory Limit: 256 MB
// Time Limit: 2000 ms
// 
// Powered by CP Editor (https://cpeditor.org)

#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define pb push_back
#define x first
#define y second 
#define int long long
#define endl '\n'
const LL maxn = 4e05+7;
const LL N = 5e05+10;
const LL mod = 1e09+7;
const int inf = 0x3f3f3f3f;
const LL llinf = 5e18;
typedef pair<int,int>pl;
priority_queue<LL , vector<LL>, greater<LL> >mi;//小根堆
priority_queue<LL> ma;//大根堆
LL gcd(LL a, LL b){
	return b > 0 ? gcd(b , a % b) : a;
}

LL lcm(LL a , LL b){
	return a / gcd(a , b) * b;
}
int n , m;
vector<int>a(N , 0);
void init(int n){
	for(int i = 0 ; i <= n ; i ++){
		a[i] = 0;
	}
}
void solve() 
{
	cin >> n >> m;
	int dp[n + 5][m + 5];
	memset(dp , 0x3f , sizeof dp);
	dp[0][0] = 0;
	for(int i = 1 ; i <= n ; i ++){
		cin >> a[i];
	}
	for(int i = 1 ; i <= n ; i ++){
		for(int j = 0 ; j <= min(i - 1 , m); j ++){//使用了j次
			for(int k = 0 ; k <= j ; k ++){//连续使用k次
				int minn = a[i];
				for(int t = i ; t >= i - k ; t --)
					minn = min(a[t] , minn);
				dp[i][j] = min(dp[i][j] , dp[i - k - 1][j - k] + (k + 1) * minn); 
			}
		}
	}
//	cout << dp[4][2] << endl;
	int ans = llinf;
	for(int i = 0 ; i <= m ; i++){
		ans = min(ans , dp[n][i]);
	}
	cout << ans << endl;
}            
signed main() 
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cout.precision(10);
    int t=1;
	cin>>t;
    while(t--)
    {
    	solve();
    }
    return 0;
}

1969D - Shop Game

题意:

思路:

思考Alice可以选择哪些商品:即的商品都可以被选择。

思考给定一个商品集合,Bob该如何选择:按照的大小从大到小排列,前个设为免费。

再思考这样一定是最优的么?不一定

若Alice抛弃一个商品,那么他将会少花费金币,而后Bob会重新按照规则选取k个,因此有可能最终花费的金币数会减少。

思考Alice按照怎么样的顺序抛弃商品:1、原先没有被Bob选中的商品一定不会被Alice抛弃。2、Alice抛弃的是被Bob选中的当中最大的那一个。

因此我们用两个优先队列来维护被Bob选中的那些商品以及没有被Bob选中的商品。

随后我们按照顺序逐个抛弃商品,求整个过程中所赚取金币的最大值即可。

cpp 复制代码
// Problem: D. Shop Game
// Contest: Codeforces - Educational Codeforces Round 165 (Rated for Div. 2)
// URL: https://codeforces.com/contest/1969/problem/D
// Memory Limit: 256 MB
// Time Limit: 2000 ms
// 
// Powered by CP Editor (https://cpeditor.org)

#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define pb push_back
#define x first
#define y second 
#define endl '\n'
#define int long long
const LL maxn = 4e05+7;
const LL N = 5e05+10;
const LL mod = 1e09+7;
const int inf = 0x3f3f3f3f;
const LL llinf = 5e18;
typedef pair<int,int>pl;
priority_queue<LL , vector<LL>, greater<LL> >mi;//小根堆
priority_queue<LL> ma;//大根堆
LL gcd(LL a, LL b){
	return b > 0 ? gcd(b , a % b) : a;
}

LL lcm(LL a , LL b){
	return a / gcd(a , b) * b;
}
int n , m;
vector<int>a(N , 0);
void init(int n){
	for(int i = 0 ; i <= n ; i ++){
		a[i] = 0;
	}
}
bool cmp(pl a , pl b){
	if(a.x != b.x){
		return a.x > b.x;
	}
	else{
		return a.y < b.y;
	}
}
void solve() 
{
	cin >> n >> m;
	vector< pair<int,int> >p(n + 5);
	for(int i = 0 ; i < n ; i ++)
		cin >> p[i].y;
	for(int i = 0 ; i < n ; i ++)
		cin >> p[i].x;
	vector< pair<int,int> > ans;
	LL cost = 0;
	for(int i = 0 ; i < n ; i ++){
		if(p[i].y <= p[i].x){
			ans.pb(p[i]);
			cost -= p[i].y;
		}
	}
	sort(ans.begin() , ans.end() , cmp);
	priority_queue<LL> ma;//拿走的
	for(int i = 0 ; i < min(m , (int)ans.size()) ; i ++){
		ma.push(ans[i].y);
	}
	priority_queue<pl> ma1;//需要购买的		
	for(int i = m ; i < ans.size() ; i ++){
		ma1.push({ans[i].x , ans[i].y});
		cost += ans[i].x;
	}
	int maxx = cost; 
	while(!ma.empty() && !ma1.empty()){
		cost += ma.top();
		cost -= ma1.top().first;
		ma.pop();
		ma.push(ma1.top().second);
		ma1.pop();
		maxx = max(maxx , cost);
	}
	cout << max(maxx , 0LL) << endl;
}            
signed main() 
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cout.precision(10);
    int t=1;
	cin>>t;
    while(t--)
    {
    	solve();
    }
    return 0;
}
相关推荐
幸运超级加倍~7 分钟前
软件设计师-上午题-16 算法(4-5分)
笔记·算法
yannan2019031315 分钟前
【算法】(Python)动态规划
python·算法·动态规划
埃菲尔铁塔_CV算法16 分钟前
人工智能图像算法:开启视觉新时代的钥匙
人工智能·算法
EasyCVR17 分钟前
EHOME视频平台EasyCVR视频融合平台使用OBS进行RTMP推流,WebRTC播放出现抖动、卡顿如何解决?
人工智能·算法·ffmpeg·音视频·webrtc·监控视频接入
linsa_pursuer18 分钟前
快乐数算法
算法·leetcode·职场和发展
小芒果_0119 分钟前
P11229 [CSP-J 2024] 小木棍
c++·算法·信息学奥赛
qq_4340859021 分钟前
Day 52 || 739. 每日温度 、 496.下一个更大元素 I 、503.下一个更大元素II
算法
Beau_Will21 分钟前
ZISUOJ 2024算法基础公选课练习一(2)
算法
XuanRanDev24 分钟前
【每日一题】LeetCode - 三数之和
数据结构·算法·leetcode·1024程序员节
gkdpjj25 分钟前
C++优选算法十 哈希表
c++·算法·散列表