首页 > 其他分享 >20230710刷题

20230710刷题

时间:2023-07-12 22:00:20浏览次数:65  
标签:cout 20230710 int s1 s0 mp front 刷题

B.Obsession with Robots

先假设除了机器人走的路其他的地方都是障碍,然后记录下来可以走的地方用BFS遍历一遍,判断一个机器人有没有bug

#include <bits/stdc++.h>
#define yes cout<<"YES"<<'\n'
#define no 	cout<<"NO"<<'\n'

using namespace std;
typedef pair<int, int> PII;
const int N = 300;
int mp[N][N];
bool st[N][N];
int dis[N][N];
struct point {
	int x;
	int y;
};
int dx[] = {0, 0, 1, -1};
int dy[] = {1, -1, 0, 0};
int main () {
	for (int i = 0; i <= 250; i++) {
		for (int j = 0; j <= 250; j++) {
			mp[i][j] = 1; //1表示不能走
		}
	}
	string s;
	cin >> s;
	int x = 105, y = 105;
	mp[x][y] = 0;//0表示可以走
	int end_x;
	int end_y;//记录终点
	for (int i = 0; i < (int)s.size(); i++) {
		if (s[i] == 'L') {
			x--;
		} else if (s[i] == 'U') {
			y++;
		} else if (s[i] == 'R') {
			x++;
		} else if (s[i] == 'D') {
			y--;
		}
		mp[x][y] = 0;//机器人走过的地方可以走
		end_x = x;
		end_y = y;//最后走到的地方就是终点
	}
	queue <point> q;
	q.push({105, 105});//起点入队
	st[105][105] = true;
	while (!q.empty()) {//开始BFS
		int front_x = q.front().x;
		int front_y = q.front().y;
		for (int i = 0; i < 4; i++) {
			int a = front_x + dx[i];
			int b = front_y + dy[i];
			if (mp[a][b] == 0 && st[a][b] == false) {//如果可以走并且没有被搜索过
				st[a][b] = true; //标记为已经搜索过
				dis[a][b] = dis[front_x][front_y] + 1; //记录走的步数
				struct point temp;
				temp.x = a;
				temp.y = b;
				q.push(temp);
			}
		}
		q.pop();
	}
	if (dis[end_x][end_y] < (int)s.size()) {//最后比较BFS的路径距离和机器人的路径距离
		cout << "BUG" << '\n';
	} else {
		cout << "OK" << '\n';
	}
	return 0;
}

B. Subsequence Hate

这个题只能是下面的这几种情况才能满足需求

000000000000

111111111111

000001111111

111111100000

所以我们要把字符串变成上面的这种情况

#include <bits/stdc++.h>
#define int long long
#define yes cout<<"YES"<<'\n'
#define no 	cout<<"NO"<<'\n'

using namespace std;
typedef pair<int, int> PII;
const int N = 1005;

int s1[N];//s1代表字符串1数量的前缀和
int s0[N];//s0代表字符串0数量的前缀和
void solve() {
	string x;
	cin >> x;
	string s = "s";
	s += x;
	for (int i = 1; i < (int)s.size(); i++) {//得到前缀和
		if (s[i] == '1') {
			s1[i] = s1[i - 1] + 1;
			s0[i] = s0[i - 1] + 0;
		}
		if (s[i] == '0') {
			s1[i] = s1[i - 1] + 0;
			s0[i] = s0[i - 1] + 1;
		}
	}
	int ans = 0x3f3f3f3f;
	int n = s.size() - 1;
	for (int i = 1; i < (int)s.size(); i++) {
		int a = s0[i] - s0[0]; //将0变成1
		a += s1[n] - s1[i]; //将1变成0;
		//都变成1111000
		int b = s1[i] - s1[0];
		b += s0[n] - s0[i];
		//都变成00000111
		ans = min(ans, min(a, b));//每次取操作次数最小的那个
	}
	cout << ans << '\n';//打印结果



}

signed main () {
	std::ios::sync_with_stdio(false), std::cin.tie(nullptr), std::cout.tie(nullptr);
	int t;
	cin >> t;
	while (t) {
		solve();
		t--;
	}


	return 0;
}

客人1是那个曲奇多吃哪一个所以可以将这些曲奇全部吃完.

而客人2是那个曲奇少吃哪一个所以我们先将饼干分配给客人2

#include <bits/stdc++.h>
#define int long long
#define yes cout<<"YES"<<'\n'
#define no 	cout<<"NO"<<'\n'

using namespace std;
typedef pair<int, int> PII;
const int N = 100008;

void solve() {
	//应该优先服务第二种客人因为第一种客人会选择多的吃也就是说
	//除了饼干没有的情况,第一种客人都不会发怒
	//而第二种客人选择饼干较少的吃就很难搞,我们模拟一下过程
	int a, b, n, m;
	cin >> a >> b >> n >> m;
	if (a <= b) { //香草小于等于巧克力
		if (m <= a) {//给二号客人吃香草的
			a -= m;//还剩下a香草
		} else {
			no;//不够吃打印no
			return;
		}
		if (a + b >= n) {//只要剩下的饼干数量大于客人1的数量就可以
			yes;//一号客人可以满足
		} else {
			no;
		}

	} else { //香草大于巧克力
		if (m <= b) { //二号客人吃巧克力
			b -= m;
		} else {
			no;//不够吃打印no
			return;
		}
		if (a + b >= n) {//只要剩下的饼干数量大于客人1的数量就可以
			yes;
		} else {
			no;

		}


	}



}

signed main () {
	std::ios::sync_with_stdio(false), std::cin.tie(nullptr), std::cout.tie(nullptr);
	int t;
	cin >> t;
	while (t) {
		solve();
		t--;
	}



	return 0;
}

A. Winner

官方题解:

问题很简单,写代码就可以了。在第一遍中计算游戏结束时每个玩家的得分总和。令 M 为这些总和中的最大值。在第二遍检查每一轮。如果当前玩家X的分数不少于M,并且他的最终分数等于M,那么他就是胜利者。下面的测试说明玩家可能会获得超过 M 分,然后失去一些,最后获胜。

#include <bits/stdc++.h>
#define int long long
#define yes cout<<"YES"<<'\n'
#define no 	cout<<"NO"<<'\n'

using namespace std;
typedef pair<int, int> PII;
const int N = 100008;



signed main () {
	int n;
	cin >> n;
	vector<pair<string, int>> a;
	map<string, int>mp;
	map<string, int>mp2;
	int m = -999999999999999;
	string s;
	int x;
	for (int i = 1; i <= n; i++) {
		cin >> s >> x;
		a.push_back({s, x});//记录数据
		mp[s] += x;//记录s当前的分数
	}
	for (auto q : mp) {//遍历mp取出最大值
		m = max(q.second, m);
	}
	string ans;//记录答案
	for (int i = 0; i < (int)a.size(); i++) {
		mp2[a[i].first] += a[i].second;//开始逐个记录答案
		if (mp[a[i].first] == m && mp2[a[i].first] >= m) {
			//如果当前的这个mp2的值大于等于m,并且最后的结果值等于m
			ans = a[i].first;//这个就是答案
			break;
		}
	}
	cout << ans << '\n';




	return 0;
}

标签:cout,20230710,int,s1,s0,mp,front,刷题
From: https://www.cnblogs.com/harper886/p/17548981.html

相关文章

  • [刷题笔记] Luogu P4017 最大食物链计数
    ProblemDescription首先明确,最大食物链指生产者到顶级消费者(即最高营养级),而不是最长的食物链这样,我们就可以将题意转化为:在一张图中,求入度为0的点到出度为0的点路径数量这不妥妥的拓扑排序嘛(这题竟然在dp训练题单里,想了好久的dp)Solution虽说是拓扑排序,但并不完全是。我们......
  • [刷题笔记] Luogu P3183 食物链
    ProblemDescription通俗一点就是在一张图上求入度为0的点到出度为0的点路径的个数。Solution简要题意后发现可以拓扑排序?这里主要介绍记忆化搜索。记忆化搜索是指记住当前节点的状态,待下次搜到这里直接调用即可,无需继续搜索。显然由记忆化搜索延伸到dp,但如果状态设计很复杂......
  • RSA刷题系列
    1,共享素数1)[闽盾杯2021]decode题目:n1:15228664629164509105936278301396170708905691970126305196584505186788860519598413718493859625462561931380632032431490419378905593909771649295663481782473029836321132574188559245931660756414915507930357509270674460219615......
  • 20230710-20230711 数论
    数论被薄纱了/kk授课老师:南京大学-朱富海教授20230710裴蜀定理对于给定不全为零的整数的\(a,b\)一定存在一对整数\(x,y\)满足\(ax+by=gcd(a,b)\)。证明:\(a==0\)\(or\)\(b==0\)显然成立;设\(gcd(a,b)=d\),即求证存在\(x,y\)满足\(ax+by=d\),等式两边同时除......
  • 20230710巴蜀暑期集训测试总结
    T1打个不太暴的暴力但是爆了。只对了subtask1,不清楚发生了什么。先建出Kruscal重构树,对每个询问二分答案,判断就用暴力启发式合并T2打了一个\(20pts\)dp。第一步没有想到,每怎么见过这种题。将问题转化为满足\(\foralli,x_i\leA_i,x_i\leB_i\)的序列\(x\)个数。枚......
  • 概率/期望dp刷题整理
    Bagofmice题意:有w只白鼠和b只黑鼠,公主和龙轮流抓老鼠,其中龙每抓一只老鼠就会有一只未被抓住的老鼠逃走,先抓到一只白鼠的获胜,问公主获胜的概率是多少Solution令dp[i][j]表示还剩i只白鼠和j只黑鼠时公主获胜的概率如果公主直接抓住一只白鼠,获胜的概率是\[\frac{i}{i+j}\]如......
  • ctfshow刷题(Java反序列化)
    CTFshowJava反序列化web846urldns链importjava.io.ByteArrayOutputStream;importjava.io.IOException;importjava.io.ObjectOutput;importjava.io.ObjectOutputStream;importjava.lang.reflect.Field;importjava.net.URL;importjava.util.Base64;i......
  • 【笔试实战】LeetCode题单刷题-编程基础 0 到 1【三】
    682. 棒球比赛题目链接682. 棒球比赛题目描述你现在是一场采用特殊赛制棒球比赛的记录员。这场比赛由若干回合组成,过去几回合的得分可能会影响以后几回合的得分。比赛开始时,记录是空白的。你会得到一个记录操作的字符串列表 ops,其中 ops[i] 是你需要记录的第 i 项操作......
  • 【笔试实战】LeetCode题单刷题-编程基础 0 到 1【二】
    1822. 数组元素积的符号题目链接1822. 数组元素积的符号题目描述已知函数 signFunc(x) 将会根据 x 的正负返回特定值:如果 x 是正数,返回 1 。如果 x 是负数,返回 -1 。如果 x 是等于 0 ,返回 0 。给你一个整数数组 nums 。令 product 为数组 nums......
  • 【笔试实战】LeetCode题单刷题-编程基础 0 到 1【一】
    1768. 交替合并字符串题目链接1768. 交替合并字符串题目描述给你两个字符串 word1 和 word2 。请你从 word1 开始,通过交替添加字母来合并字符串。如果一个字符串比另一个字符串长,就将多出来的字母追加到合并后字符串的末尾。返回 合并后的字符串 。示例1:输入:wor......