Codeforces Round 903 (Div. 3)

A. Don't Try to Count

大概题意给你两个字符串a,b。a串可进行的操作为将整个a串复制到之前的a串后面(直接用a+a即可),然后看操作多少次可以让b串变为a串的子串如果不能就输出-1。

#include <iostream>
using namespace std;
string a,b;
void solve()
{
int n,m;
cin>>n>>m;
cin>>a>>b;
int cnt=0;
while(n<m)
{
a=a+a;
n<<=1;
cnt++;
}
for(int i=0;i<n;++i)
{
bool pd=1;
for(int j=i;j<i+m;++j)
{
if(a[j]!=b[j-i])
{
pd=0;
break;
}
}
if(pd)
{
cout<<cnt<<endl;
return ;
}
}
a=a+a;
n<<=1;
cnt++;
for(int i=0;i<n;++i)
{
bool pd=1;
for(int j=i;j<i+m;++j)
{
if(a[j]!=b[j-i])
{
pd=0;
break;
}
}
if(pd)
{
cout<<cnt<<endl;
return ;
}
} cout<<-1<<endl;
}
int main() {
int t;
cin>>t;
while(t--) {
solve();
}
return 0;
}

B. Three Threadlets

题意:给三个数,分开他们使得剩下的为相同的

思路:三次分法,可以不完全用,所以只需要考虑最差的情况,将三个数排序为max,min,mid。如果三个数相等直接输出“YES”,如果三个数不相等的话那么就不能分min,如果mid也可以不分的话那么就有这两种情况

$$

max:mid:min=3:2:1(三次都用)/2:2:1(只用两次)

$$

如果mid=min那么只有max需要分那么就有比例为

$$

max:mid:min=4:1:1/3:1:1/2:1:1

$$

#include <iostream>
using namespace std;
void solve(){
int a,b,c;
cin>>a>>b>>c;
if(a==b&&b==c) {
cout<<"YES"<<"\n";
return ;
}int ma=a,mi=a;
ma=max(ma,b);
ma=max(ma,c);
mi=min(mi,b);
mi=min(mi,c);
int mid=a+b+c-mi-ma;
if(ma==2*mi&&mid==2*mi) {
cout<<"YES"<<"\n";
return ;
}if(mid==mi&&ma==3*mi){
cout<<"YES"<<"\n";
return ;
}if(ma==3*mi&&mid==2*mi) {
cout<<"YES"<<"\n";
return ;
}if(mid==mi&&ma==2*mi){
cout<<"YES"<<"\n";
return ;
}if(mid==mi&&ma==4*mi){
cout<<"YES"<<"\n";
return ;
}
cout<<"NO"<<"\n";
}
int main() {
int t;
cin>>t;
while(t--){
solve();
}
return 0;
}

C. Perfect Square

题意:有一个正方形矩阵,我们对其的操作一次为将一个字母++,当这个字母变成'z'时就不会再改变了,问多少次之后我们旋转90°之后和原来的矩阵重合

思路:一共有四种(90/360),我们可以求出这四个坐标中最大的,然后剩下的++记作一次操作

#include <bits/stdc++.h>
using namespace std;
char mp[1010][1010];
void solve(){
int m;
cin>>m;
long long int res=0;
for(int i=1;i<=m;i++){
for(int j=1;j<=m;j++){
cin>>mp[i][j];
}
}
for(int i=1;i<=m/2;i++){
for(int j=1;j<=m/2;j++){
int ma=max(mp[i][j],max(mp[m-j+1][i],max(mp[m-i+1][m-j+1],mp[j][m-i+1])));
res+=ma*4-mp[i][j]-mp[m-j+1][i]-mp[m-i+1][m-j+1]-mp[j][m-i+1];
}
}
cout<<res<<endl;
}
int main()
{
int t;
cin>>t;
while(t--){
solve();
}
return 0;
}

D. Divide and Equalize

题意:操作:找到一个数x使得ai=ai/x;aj=aj/x;要求:所有数相等

思路:这个变化会使他的乘积没有变化,故我们可知他们的乘积为一个数的n次方,那么他的因数个数应该为n的倍数。

板子:质因数分解

void divide(int x)
{
for (int i = 2; i <= x / i; i ++ )
if (x % i == 0)
{
int s = 0;
while (x % i == 0) x /= i, s ++ ;
cout << i << ' ' << s << endl;
}
if (x > 1) cout << x << ' ' << 1 << endl;
cout << endl;
}
#include <bits/stdc++.h>
using namespace std;
void solve(){
int n;
cin>>n;
map<int,int> q;
for(int j=0;j<n;j++){
int x;
cin>>x;
for (int i = 2; i <= x / i; i ++ )
if (x % i == 0)
{
int s = 0;
while (x % i == 0) x /= i, s ++ ;
q[i]+=s;
}
if (x > 1) q[x]++;
}
for(auto x:q){
if(x.second%n!=0){
cout<<"NO"<<"\n";
return ;
}
}
cout<<"YES"<<"\n";
}
signed main() {
int t;
cin>>t;
while(t--){
solve();
}
return 0;
}

E. Block Sequence

题意:操作:删除一个数;要求:让数列分成一块一块的(什么叫块:假设你a[i]=x,那么a[i]~a[i+x-1]为一个块)

1.把自身直接删了dp[i]=dp[i-1]+1;

2.假设左边已经有一个完美的块,要使整个序列都为完美,只需要后面也为完美块,假设后面的数<a[i],dp[i]=d[i+1]+1;如果相等dp[i]=0,如果后面的数>a[i]那么dp[i]=ap[i+a[i]+1];

#include <bits/stdc++.h>
using namespace std;
const int MAX=1e6+10;
int dp[MAX],arr[MAX];
void solve()
{
int n;
cin>>n;
for(int i=1;i<=n;i++){
cin>>arr[i];
}
dp[n + 1] = 0;
for(int i = n; i >= 0; i --)
{
if(arr[i] + i > n) dp[i] = dp[i + 1] + 1;
else if(arr[i] + i == n) dp[i] = 0;
else dp[i] = dp[i + arr[i] + 1];
dp[i] = min(dp[i], dp[i + 1] + 1);
}
cout << dp[0] << '\n';
}
int main()
{
int t;
cin>>t;
while (t--){
solve();
}
return 0;
}

F. Minimum Maximum Distance

题意:求min(max(顶点到所有标记点距离))

思路:树上任一点到其他点最远的距离即为到树的直径的两个端点中的一个的距离,跑两遍bfs求一下两个端点,最后再求所有最大值中的最小值即可

板子:bfs

queue<int> q;
st[1] = true; // 表示1号点已经被遍历过
q.push(1); while (q.size())
{
int t = q.front();
q.pop(); for (int i = h[t]; i != -1; i = ne[i])
{
int j = e[i];
if (!st[j])
{
st[j] = true; // 表示点j已经被遍历过
q.push(j);
}
}
}
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N = 400010;
vector<int> v[N];
int dist[N], f[N];
int st[N];
int n, k; int bfs(int u)
{
for (int i = 1; i <= n; i++)dist[i] = -1;
queue<int> q;
q.push(u);
dist[u] = 0; while (q.size())
{
int t = q.front();
q.pop();
for (auto i : v[t])
{
int j = i;
if (dist[j] == -1)
{
dist[j] = dist[t] + 1;
q.push(j);
}
}
} int ans = -1;
for (int i = 1; i <= n; i++)
{
if (st[i] && (ans == -1 || dist[i] > dist[ans]))
{
ans = i;
}
}
return ans;
}
void solve()
{
cin >> n >> k;
for (int i = 1; i <= n; i++)
{
v[i].clear();
}
for (int i = 1; i <= n; i++)st[i] = 0;
for (int i = 1; i <= k; i++)
{
int x;
cin >> x;
st[x] = 1;
}
int m = n - 1;
while (m--)
{
int a, b;
cin >> a >> b;
v[a].push_back(b);
v[b].push_back(a);
} int a = bfs(1);
int b = bfs(a);
for (int i = 1; i <= n; i++)f[i] = dist[i];
bfs(b); for (int i = 1; i <= n; i++)
{
f[i] = max(f[i], dist[i]);
}
int minans = 1e18;
for (int i = 1; i <= n; i++)
{
minans = min(minans, f[i]);
}
cout << minans << endl;
} signed main()
{
int t;
cin>>t;
while (t--)
{
solve();
} }

Codeforces Round 903 (Div. 3)的更多相关文章

  1. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  2. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  3. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  6. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

  7. Codeforces Round #262 (Div. 2) 1004

    Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...

  8. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

  9. Codeforces Round #268 (Div. 2) ABCD

    CF469 Codeforces Round #268 (Div. 2) http://codeforces.com/contest/469 开学了,时间少,水题就不写题解了,不水的题也不写这么详细了 ...

  10. 贪心+模拟 Codeforces Round #288 (Div. 2) C. Anya and Ghosts

    题目传送门 /* 贪心 + 模拟:首先,如果蜡烛的燃烧时间小于最少需要点燃的蜡烛数一定是-1(蜡烛是1秒点一支), num[g[i]]记录每个鬼访问时已点燃的蜡烛数,若不够,tmp为还需要的蜡烛数, ...

随机推荐

  1. 连续下雨天,.net开发者如何预防流感

    最近连续下了3天雨,天气变化大,很容易引发感冒咳嗽等疾病.对于.NET技术开发人员来说,如何保持身体健康,保证工作效率是一个很重要的问题. 首先,我们需要注意保持室内空气流通,避免长时间处于封闭的空间 ...

  2. [kafka]部署安装单节点

    前言 kafka 3.0之前的版本需要依赖zookeeper,3.0版本之后可不依赖zookeeper. 基于zookeeper的安装步骤 节点IP:172.50.13.103 kafka版本:2.7 ...

  3. 【译】摇摆你的调试游戏:你需要知道的 Parallel Stack Window 小知识!

    在 Visual Studio 2022 17.6和17.7中,我们在 Parallel Stack 窗口中添加了大量新功能,可以将您的多线程调试提升到一个新的水平. 但是 Parallel Stac ...

  4. 针对sarasa-shuffle.woff2加密字体进行解密

    本文针对的是类似于sarasa-shuffle.woff2加密字体的一个研究. 字体加密是使用Unicode编码将其映射到不同的字体显示的一种前端显示加密手段.在反爬虫中能够起到较好的效果,爬虫将只能 ...

  5. 【HCDG城市行东莞站】松山湖开发者村助力企业释放数字新动能

    本文分享自华为云社区<[HCDG城市行东莞站]从"数据治理"洞察"数字化运营之道",松山湖开发者村助力企业释放数字新动能!>,作者:华为云社区精选. ...

  6. HDU 1171 0-1背包

    最近感觉DP已经完全忘了..各种爆炸,打算好好复习一发,0-1背包开始 Big Event in HDU Problem Description Nowadays, we all know that ...

  7. Llama2-Chinese项目:2.1-Atom-7B预训练

      虽然Llama2的预训练数据相对于第一代LLaMA扩大了一倍,但是中文预训练数据的比例依然非常少,仅占0.13%,这也导致了原始Llama2的中文能力较弱.为了能够提升模型的中文能力,可以采用微调 ...

  8. 命令vue inspect > output.js报错:在此系统上禁止运行脚本

    用的这个命令去看output.js文件,结果报错. 解决方案是去对应目录下删掉vue.ps1就OK了 .

  9. 以太坊和比特币区块链的异同(一些QA)

    1.比特币区块链和以太坊区块链有何区别? 比特币区块链与以太坊在设计和功能上有显著的不同.下面是关于比特币的主要点: 没有智能合约功能(按照以太坊的定义):比特币是为了作为一个去中心化的数字货币而创建 ...

  10. dijkstra算法(朴素 + 堆优化)

    dijkstra算法的大题思路是通过n - 1次迭代,每次迭代把一个点距汇点的最短路确定,当n - 1次循环过后所有点的最短路都已经确定 注意:dijkstra算法只适用于没有负权边的单源最短路 以下 ...