Acwing第46场周赛-2022/4/9

1.题目链接 4396.取石子

#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
int n1, n2, k1, k2;
int main()
{
cin >> n1 >> n2 >> k1 >> k2;
if(n1 <= n2) puts("Second");
else if(n1 > n2) puts("First");
return 0;
}

2.题目链接 4397.卡牌

#include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
using namespace std;
const int N = 200010;
int n, m;
int a[N], b[N];
int ans;
priority_queue<int> q;
int main()
{
cin >> n >> m;
for (int i = 1; i <= n; i ++ )
{
scanf("%d", &a[i]);
ans += a[i];
}
for (int i = 1; i <= n; i ++ ) scanf("%d", &b[i]);
for (int i = 1; i <= n; i ++ )
{
int c = a[i] - b[i]; //差值越大越好
q.push(c);
}
// cout << ans << endl;
while(q.size() > m)
{
auto t = q.top();
//cout << t << endl;
if(t < 0) break;
q.pop();
ans -= t;
}
printf("%d\n", ans);
return 0;
}

3.题目链接 4398.查询字符串

#include <iostream>
#include <cstring>
#include <algorithm>
#include <map>
#include <set>
using namespace std;
const int N = 10010;
char str[N][10];
map<int, string> heap;
map<string, int> mp;
map<string, int> hs;
void mp_insert(string str, int k)
{
set<string> st;
int len = str.size();
for(int i = 0; i < len; i ++)
for(int j = 1; j <= len - i; j ++)
st.insert(str.substr(i, j));
for(auto x : st) mp[x] ++, hs[x] = k;
}
int main()
{
int n;
cin >> n;
for (int i = 1; i <= n; i ++ )
{
cin >> str[i];
heap[i] = str[i];
mp_insert(str[i], i);
}
//for(auto [a, b] : heap) cout << a << ' ' << b << endl;
//cout << endl << endl << endl;
//for(auto [a, b] : mp) cout << a << ' ' << b << endl;
int m;
cin >> m;
while (m -- )
{
string s;
cin >> s;
if(mp.count(s))
{
int t = hs[s];
cout << mp[s] << ' ' << heap[t] << endl;
}
else cout << "0 -" << endl;
}
return 0;
}
posted @   冯大善人  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示