首页 > 其他分享 >codeforces比赛(1):codeforces 918_div4

codeforces比赛(1):codeforces 918_div4

时间:2023-12-29 12:44:07浏览次数:47  
标签:tmp 题目 int sum codeforces long solve 918 div4

A、Odd One Out

跳转原题点击此:A题地址

1、题目大意

  给你三个数,其中两个是相等的,问你还有一个不相等的数是多少。

2、题目解析

  直接暴力枚举即可,只要找到两个数相等,那么答案就是另一个数。

#include<bits/stdc++.h>

using namespace std;

int T;
int a, b, c;

void solve()
{
	cin >> a >> b >> c;
	if(a == b)
		cout << c << endl;
	else if(a == c)
		cout << b << endl;
	else
		cout << a << endl;
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}

	return 0;
}

 

B、Not Quite Latin Square

跳转原题点击此:B题地址

1、题目大意

  给定一个3X3的矩阵各由3个A、B、C组成,并且每行每列不能相同。这时拿走一个并用\(?\)代替,问你拿走的这个字符是什么。

2、题目解析

  因为每次最多9个字符,所以输入的时候统计下,只要哪个字符不等于3个,那答案就是他

#include<bits/stdc++.h>

using namespace std;

int T;

void solve()
{
	char f[10][10];
	int ff[5] = {0};
	for(int i = 1; i <= 3; i++)
	{
		for(int j = 1; j <= 3;j ++)
		{
			cin >> f[i][j];
			if(f[i][j] != '?')
			{
				char tmp = f[i][j] - 'A' + 1;
				ff[tmp] ++ ;
			}
		}
	}
	for(int i = 1; i <= 3; i++)
	{
		if(ff[i] != 3)
		{
			cout << char('A' + i - 1) << endl;
			return;
		}
	}
	
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}
	return 0;
}

 

C、Can I Square?

跳转原题点击此:C题地址

1、题目大意

  Calin由n个桶,每个桶里面有\(a_i\) 个 \(1 * 1\)积木,问你所有的积木全部用上能否拼成一个正方形

2、题目解析

  只需要判断所有积木加起来能否被完全开方,因为要拼成正方形,所以每个正方形面积就是:1、4、6、...、以此类推。
  要注意两个点:1、sqrt只能用于浮点数开方,并且返回的可能有小数,所以要判断;2、double类型的数据范围是-2^1024 ~ +2^1024,比long long 大,所以放心全部累加吧。

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;
int T;
int n;
double f[N];

void solve()
{
	cin >> n;
	double tmp = 0;
	for(int i = 1; i <= n; i++)
	{
		cin >>f[i];
		tmp += f[i];
	}
	
	ll x = sqrt(tmp);	// 去除开方后的小数部分(如果有的话)
	if(x * x == tmp)	// 如果等于原数据,说明开方后是没有小数的
		cout << "YES" << endl;
	else
		cout << "NO" << endl;
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}

	return 0;
}

 

D、Unnatural Language Processing

跳转原题点击此:D题地址

1、题目大意

  Lura想创造一种新的语言,该语言包含\(a、e作为v元音\) 和 \(b、c、d作为C辅音\),要求创造的音节只能是 CV 两个字符 或者 CVC 三个字符,当Lura创造好单词后,发现需要用 “.”来将单词分为音节,请你帮他分。

2、题目解析

  因为题目保证是肯定有答案的,所以我们从后往前判断,找到符合条件的就通过数组记录下来。例如我们找到V音节的,就需要找到后面是C字节的;找到C字节的,就需要找到第二个C字节的。最后在输出即可。

#include<bits/stdc++.h>

using namespace std;

const int N = 2e5+10;

int T;
int n;
bool st[N];

void solve()
{
	string s;
	cin >> n >> s;
	memset(st, 0, sizeof st);
	
	int x = 0;
	for(int i = s.size() - 1; i >= 0; i--)
	{
		// 用X记录是找哪种形式,然后找对于音节的头
		if(x == 1)
		{
			if(s[i] == 'b' || s[i] == 'c' || s[i] == 'd')
			{
				st[i] = true;
				x = 0;
				continue;
			}
		}
		
		if(s[i] == 'a' || s[i] == 'e')	// 来寻找CV形式的音节
		{
			x = 1;
			continue;
		}
		else if(s[i] == 'b' || s[i] == 'c' || s[i] == 'd')	// 寻找cvc形式的音节
		{
			x = 1;
			continue;
		}
	}
	for(int i = 0; i < s.size(); i++)
	{
		if(st[i] == 1 && i != 0)	// 注意第一个不输入分隔符
			cout << "." << s[i];
		else
			cout << s[i];
	}
	cout << "\n";
	
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}

	return 0;
}

 

E、Romantic Glasses

跳转原题点击此:E题地址

1、题目大意

  有n杯果汁,其中Iulia只喝奇数杯的,她男朋友只喝偶数杯。Iulia想要选中某个区间的果汁,使得该区间的奇数杯果汁总量之和等于偶数杯果汁之和,问你是否存在该区间。

2、题目解析

  我们只需要通过map存入奇数杯和偶数杯的某个区间差异,只要差异值重复过,说明肯定存在某个区间相等。
  1、那如何更新差异值:即通过sum不断加减奇偶的果汁数;
  2、那如何保证该差异值是某个区间的差异值:注意是通过奇偶的相加相减抵消了这种差异:
  例如:[6,3,1,3,2]:第一次:sum为6,第二次:sum为3,第三次:sum为4,第四次:sum为1,第五次:sum为3。此时sum为3出现过,说明找到了正确区间。这是因为,第二次sum为3时,到最终重复3,这个从l=3到r=5这个区间的奇数杯和偶数杯果子加减为0,所以重复3。

#include<bits/stdc++.h>

using namespace std;

typedef long long ll;

int T;
int n;

void solve()
{
	cin >> n;
	vector<ll> a(n + 1);
	for(int i = 1; i <= n; i++)
		cin >> a[i];

	// 即将奇数和偶数杯的果子差异存入mp中
	// 只要出现过这种差异,就赋值为1
	map<ll, ll> mp;
	mp[0] = 1;	// 初始差异为0,存入
	
	// 注意开ll,数据比较大
	ll sum = 0;	// sum是用来表示奇数杯和偶数杯的果子差异
	for(int i = 1; i <= n; i++)
	{
		// 根据奇偶的不同更新差异值
		if(i & 1)
			sum += a[i];
		else
			sum -= a[i];
		// 只要发现出现的差异曾经出现过,说明肯定存在答案
		if(mp[sum] == 1)
		{
			cout << "YES" << endl;
			return;
		}
		mp[sum] = 1;
	}
	cout << "NO" << endl;
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}

	return 0;
}

 

F、题目

跳转原题点击此:F题地址

1、题目大意

  有n个人,这几个人每个人都从各自的起点(\(a_i\))一每次1格的速度到各自的终点(\(b_i\)),并且保证(\(a_i < b_i\) 和 每个人的起点与终点不会有重复)。当两个人相遇时,会打招呼。问你一共打了几次招呼。

2、题目解析

  由于起点和终点不会重复 且 速度都是一样的,所以只有当到达某个人的终点时,双方才会打招呼。并且当自己的路程包含了其他的人时,说明打的招呼人数就是包含里的人总和
  所以我们对起点排序,当起点较小时找到他的终点在原始数组的下标(这代表在原始数组排名第几,比他小的就是大的招呼人数)。
  注意:代码有点极限,不要用longlong开数组,会超时。

#include<bits/stdc++.h>

using namespace std;

#define _1 first
#define _2 second

typedef pair<int, int>pii;

int T;
int n;

void solve()
{
	cin >> n;
	vector<pii> a(n);	// 注意sort是全部,所以不要多开
	vector<int> b(n);
	for(int i = 0; i < n; i++)
	{
		cin >> a[i]._1 >> a[i]._2;
		b[i] = a[i]._2;
	}
	
	sort(a.begin(), a.end());	// 按照起始位置排序
	sort(b.begin(), b.end());	// 按照终点位置排序
	
	long long ans = 0;
	for(int i = 0; i < n; i++)
	{
		int end = a[i]._2;
		// lower_bound 找到第一个大于等于end的地址,减去头地址,返回下标
		// tmp:表示在该人起点较小时,所有比该人终点小的,都会碰见。
		int tmp = lower_bound(b.begin(), b.end(), end) - b.begin();
		// 加上的是下标(代表有几个人前面,因为是从0开始,所以无需减一)
		ans += tmp;
		// 去除该人
		b.erase(b.begin() + tmp, b.begin() + tmp + 1);
	}
	cout << ans << endl;
	
}

int main()
{
	cin >> T;
	while (T--)
	{
		solve();
	}

	return 0;
}

 

G、Bicycles

跳转原题点击此:G题地址

这是一道Dijkstra的题目,我目前水平无法写出来,我只会套用dijk模板,未来补上。

标签:tmp,题目,int,sum,codeforces,long,solve,918,div4
From: https://www.cnblogs.com/Tom-catlll/p/17934641.html

相关文章

  • Codeforces Round 917 (Div. 2)
    A.LeastProduct存在\(a[i]=0\),\(min=0\),不需要任何操作。负数个数为偶数(包括0),\(min=0\),把任意一个改为\(0\)。负数个数为奇数,\(min=\proda[i]\),不需要任何操作。voidsolve(){ intn; cin>>n; vector<int>b,c,d; for(inti=0;i<n;++i){ in......
  • [Codeforces] CF1536C Diluc and Kaeya
    CF1536CDilucandKaeya题意题目传送门给你一个字符串\(S\),其中只包含'K'或'D'两种字符,要求划分这个字符串使得各部分的\(n(D):n(K)\)相同,其中\(n(D)\)表示\(S\)中字符'D'出现的个数,最大化划分后形成的组数。求出\(S\)的所有前缀中的上述答案。思路注意到,如......
  • codeforces刷题(1100):1901B_div2
    B、ChipandRibbon跳转原题点击此:该题地址1、题目大意  存在一条由n个单元格组成的带子。chip可以做两个操作:1、由\(i\)走到\(i+1\),但是不能走到\(i-1\);2、可以传送到任意位置,包括传送到原地。每到一个单元格,该单元格的数值+1(初始为0)。最开始chip在从第一格开始走起(题......
  • codeforces刷题(1100):1902B_div2
    B、GettingPoints跳转原题点击此:该题地址1、题目大意  Monocarp为了完成总共n天的某学期的p学分任务。Monocarp每天可以选择两种度过方式:上一次课和完成最多两个任务或者休息一天。其中上课获得l学分,每个任务获得t学分,其中任务不可以重复接取,并且每周获得一个新的任务(第一......
  • 「题解」Codeforces 1427G One Billion Shades of Grey
    感谢127的指导/ll\(|h_u-h_v|=\max(0,h_u-h_v)+\max(0,h_v-h_u)\),那么可以把它看成这样的问题:\[\min\{\sum_{(u,v)}\max(0,h_u-h_v+w_{u,v})c_{u,v}\}\]对偶一下,问题就变为:如果两个格子相邻就互相连容量为\(c_{u,v}=1\),费用为\(w_{u,v}=0\)的边,跑最大费用循环流。为了限......
  • codeforces刷题(1100):1904B_div2
    B、CollectingGame跳转原题点击此:该题地址1、题目大意  获得一个由n位正整数组成的数组。你可以选择选择任意一个数作为你的判断值。然后任意一个\(\le\)它的数可以被选中加入你的分数(注意判断值不算在里面),同时该数被移除数组。你的任务是,对于该数组中的每个数,都将其作为......
  • codeforces刷题(1100):1905B_div2
    B、Begginer'sZelda跳转原题点击此:此题地址1、题目大意  给你一个子树,你可任意选择两个节点\(u、v\),这两个节点之间的所有节点(包括\(u、v\))都将结合变为一个新的节点。要求你通过该操作将所有的节点变为只有一个节点,求最小的操作数。2、题目解析  由题意可得:当\(u、v\)......
  • CodeForces 1917E Construct Matrix
    洛谷传送门CF传送门\(2\nmidk\)显然无解。若\(4\midk\),发现给一个全\(2\times2\)子矩形全部异或\(1\)不会对行异或和和列异或和造成影响。那么我们找到\(\frac{k}{4}\)个全\(0\)的\(2\times2\)子矩形填\(1\)即可。否则若\(k=2\)或\(k=n^2-2\)......
  • CodeForces 1917F Construct Tree
    洛谷传送门CF传送门考虑形式化地描述这个问题。先把\(l\)排序。然后相当于是否存在一个\(\{1,2,\ldots,n\}\)的子集\(S\),使得:\(\sum\limits_{i\inS}l_i=d\)。\(\existsT\subseteqS,\max\limits_{i\notinS}l_i\le\min(\sum\limits_{i\inT}l_i,\sum......
  • Codeforces Round 915 (div2) E
    E.TreeQueries[题目链接](https://codeforces.com/contest/1904/problem/EProblem-E-Codeforces)题意概括:给定一棵大小为\(n\)的树,回答如下询问,询问之间相互独立:给定一个点\(x\)与\(k\)个点\(a_i\),求出从\(x\)出发不经过任何一个\(a_i\)的最长简单路径长度......