ICPC网络赛第一场 挨打实录

L KaChang!

这题很简单,看懂就能做。

找出y的几倍能大于等于所给的所有数,同时倍数必须大于等于2;

因此,我们直接找出这组数中最大的一个,对y做除法并向上取整就好了。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
signed main()
{
	int n,y;
	cin>>n>>y;
	int maxn=-1;
	for(int i=1;i<=n;i++)
	{
		int x;
		cin>>x;
		maxn=max(maxn,x);
	}
	int d=maxn/y;
	if(maxn%y) d++;
	cout<<max(d,2);
	
    return 0;
}

A 预选赛排名规则

做题重点在于理解题意。我们做的时候看不懂题目,根据样例反推的。

我一开始以为每次只要能就必须要输出一组的string,后来根据样例反推发现,如果这一组的string刚好输出过了,那么直接输出另一组的string就好了。

"使用合并排序方法合并大学的两个排名。对于任何两所大学在不同比赛中获得相同排名的,在第一场比赛中获得此排名的大学将排名第一。"

也就是按排名排序,第一组中排第一的第一个输出,第二组排第一的下一个输出,

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+10;
map<string,int> mp1,mp2,mp3;
vector<string> v1,v2;
signed main()
{
	int m,n;
	cin>>m>>n;
	for(int i=1;i<=m;i++)
	{
		string x;
		cin>>x;
		if(!mp1[x]) 
		{
			v1.push_back(x);
			mp1[x]=1;
		}
	}
	for(int i=1;i<=n;i++)
	{
		string x;
		cin>>x;
		if(!mp2[x]) 
		{
			v2.push_back(x);
			mp2[x]=1;
		}
	}
	
	int len=0;
	for(;len<min(v1.size(),v2.size());len++)
	{
		if(!mp3[v1[len]])
		{
			mp3[v1[len]]=1;
			cout<<v1[len]<<endl;
		}
		if(!mp3[v2[len]])
		{
			mp3[v2[len]]=1;
			cout<<v2[len]<<endl;
		}
	}
	if(len<v1.size())
	{
		for(;len<v1.size();len++)
		{
			if(!mp3[v1[len]])
			{
				cout<<v1[len]<<endl;
			}
		}
	}
	if(len<v2.size())
	{
		for(;len<v2.size();len++)
		{
			if(!mp3[v2[len]])
			{
				cout<<v2[len]<<endl;
			}
		}
	}
	
    return 0;
}

D Transitivity

更新中......

相关推荐
宝贝儿好1 天前
【强化学习实战】第十一章:Gymnasium库的介绍和使用(1)、出租车游戏代码详解(Sarsa & Q learning)
人工智能·python·深度学习·算法·游戏·机器学习
weixin_458872611 天前
东华复试OJ二刷复盘2
算法
Charlie_lll1 天前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人1 天前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
wen__xvn1 天前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答1 天前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展
Neteen1 天前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.1 天前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区1 天前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展
再难也得平1 天前
力扣239. 滑动窗口最大值(Java解法)
算法·leetcode·职场和发展