Acwing 周赛28

题面1

给定一个由大写字母构成的字符串 s,请计算其中有多少个子序列 QAQ。

注意,子序列不需要连续。

提示:本题数据范围较小,可以直接三重循环枚举三个字母的位置。

输入格式

一行,一个由大写字母构成的字符串 s。

输出格式

一个整数,表示 s 中子序列 QAQ 的个数。

数据范围

所有测试点满足 1≤|s|≤100。

输入样例1:

QAQAQYSYIOIWIN

输出样例1:

4

输入样例2:

QAQQQZZYNOIWIN

输出样例2:

3

Hint

注意子序列是可以不连续的 比如QAQQ 是有两个QAQ序列的

sol

注意到题面的数据范围是<=100的,也就是可以O(n^3)的解法。

也就是枚举每一个字母的位置,然后判断

代码

#include<iostream>
#include<utility>
#include<string>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
string sam;
cin >> sam;
int cnt = 0;
fi(i,0,sz(sam)-1)
fi(j,i+1,sz(sam)-1)
fi(k,j+1,sz(sam)-1){
if(sam[i] == 'Q' && sam[j] == 'A' && sam[k] == 'Q')
cnt++;
}
cout << cnt << endl;
return 0;
}

题面2

给定一个长度为 n 的整数序列 a1,a2,…,an。

请你从中选出尽可能多的数。

要求满足如下两个条件之一:

仅选择一个数;

选择至少两个数,且所选择的数的最大公约数大于 1;

输出选出数的最大可能数量。

输入格式

第一行包含整数 n。

第二行包含 n 个整数 a1,a2,…,an。

输出格式

一个整数,表示选出数的最大可能数量。

数据范围

前 6 个测试点满足 1≤n≤10。

所有测试点满足 1≤n≤105,1≤ai≤105。

输入样例1:

3

2 3 4

输出样例1:

2

输入样例2:

5

2 3 4 6 7

输出样例2:

3

Hint

第一个样例选择2和4,最大公约数是2

第二个样例选择2,4,6,最大公约数是2

sol

如果要尽可能地选择多的数,那么肯定存在一个数是他们的最大公约数

1.如果选择的数中有最大的公约数,那么这个数显然是所选择序列中较小的数

我们可以尝试把每个数的质因子给筛出来,然后统计质因子最多的数,这样就是最终的答案

上述我们选择的这个数如果

是一个质数,上述的解法显然成立,可以用反证法证明

是一个合数,那么他肯定是某几个质数的乘积,那么上述的解法仍然正确,可以举例子说明

2.如果选择的数中没有最大的公约数

此情况其实等价于合数的情况

筛质因数的时间复杂度为O(n^1/2)

总的时间复杂度为O(n^3/2)

代码

#include<iostream>
#include<utility>
#include<unordered_map>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
unordered_map<int,int> mapp;
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
int n;
cin >> n;
fi(i,1,n){
int x;
cin >> x;
fi(j,2,x/j){
if(x % j == 0){
mapp[j]++;
while(x % j == 0){
x /= j;
}
}
}
if(x > 1) mapp[x]++;
}
int ans = 0;
for(auto p:mapp) ans = max(ans,p.y);
if(ans != 0)
cout << ans << endl;
else
cout << 1 << endl;
return 0;
}

题面3

有 n 个小朋友,编号 1∼n。

每个小朋友都拿着一个号码牌,初始时,每个小朋友拿的号码牌上的号码都等于其编号。

每个小朋友都有一个幸运数字,第 i 个小朋友的幸运数字为 di。

对于第 i 个小朋友,他可以向第 j 个小朋友发起交换号码牌的请求,当且仅当 |i−j|=di 成立。

注意,请求一旦发出,对方无法拒绝,只能立刻进行交换。

每个小朋友都可以在任意时刻发起任意多次交换请求。

给定一个 1∼n 的排列 a1,a2,…,an。

请问,通过小朋友相互之间交换号码牌,能否使得第 i 个小朋友拿的号码牌上的号码恰好为 ai,对 i∈[1,n] 均成立。

输入格式

第一行包含整数 n。

第二行包含 n 个整数 a1,a2,…,an。

第三行包含 n 个整数 d1,d2,…,dn。

输出格式

共一行,如果能做到,则输出 YES,否则输出 NO。

数据范围

前 6 个测试点满足 1≤n≤10。

所有测试点满足 1≤n≤100,1≤di≤n,保证 a1∼an 是一个 1∼n 的排列。

输入样例1:

5

5 4 3 2 1

1 1 1 1 1

输出样例1:

YES

输入样例2:

7

4 3 5 1 2 7 6

4 6 6 1 6 6 1

输出样例2:

NO

输入样例3:

7

4 2 5 1 3 7 6

4 6 6 1 6 6 1

输出样例3:

YES

Hint

对于第一个样例,刚开始都是1,2,3,4,5

经过一系列交换后显然可以成为5,4,3,2,1

每一个数只能跟他相邻的数交换

sol

刚开始看到数据只有100,想试试能不能用bfs搜素,因为这道题和八数码很像

写了一遍发现只能过将近一半的点

后面写了启发式搜素,虽然速度明显提升了很多,但是还是不能通过全部的点

当然,本题不是八数码那种类型,对于这个序列的每一个位置,只有两种可能去的点,而且每一个点不一定是可达的。如果是可达的,我们对这两个点进行建边,然后用floyd跑一遍,如果两个对应的点是可达的,

就说明对应的数可以通过这一系列交换使得对应的数互换位置,间接地说明其是可达的

算法时间复杂度为O(n^3)

此题有个很有趣的地方就是这个图最后跑出来是g[i][j]

i一定能通过一系列的变换到j,也就是i和j最后会实现交换

并且他们中间路径上的数也可以实现交换

最后的结果是只有i和j交换了,其他路上交换过的数都可以重新交换回来

之前想过一个问题就是,如果g[1][5]存在,那么1和5交换了,但是有可能5那个位置需要的不是1,而是4

那么如果g[5][4]存在

4无论之前通过怎样的交换,在最后都可以换到4这个位置来,然后到5的位置

做个推广,如果一个点到另一个点可达,那么他们路上的点到另一个点也是可达的

这个关系映射到这道题中就是无论4之前换到了任何其他位置,那么他还是可以换回到5这个位置

可以称之为交换的恒定有效性

代码

普通的bfs可以过接近一半的点

#include<iostream>
#include<utility>
#include<string>
#include<unordered_map>
#include<queue>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
unordered_map<string,int> uor;
const int N = 105;
int d[N];
void bfs(string ss,string mir){
queue<string> que;
que.push(ss);
while(!que.empty()){
string p = que.front();
que.pop();
// cout << p << endl;
if(p == mir) {cout << "YES" << endl; return;}
uor[p]++; fi(i,0,sz(p) - 1){
if(i + d[i] < sz(p)){
string temp = p;
swap(temp[i],temp[i+d[i]]);
// cout << temp << endl;
if(!uor[temp])
que.push(temp);
}
if(i - d[i] >= 0){
string temp = p;
swap(temp[i],temp[i - d[i]]);
if(!uor[temp])
que.push(temp);
}
} }
cout << "NO" << endl;
return;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
int n;
cin >> n;
string Balloon;
string mir; fi(i,1,n){
char c;
cin >> c;
Balloon.push_back(c);
}
fi(i,1,n) mir.push_back((char)(i+48)); fi(i,0,n-1) cin >> d[i]; bfs(mir,Balloon);
return 0;
}

启发式搜素可以过一半的点

#include<iostream>
#include<utility>
#include<string>
#include<unordered_map>
#include<queue>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
unordered_map<string,int> uor;
const int N = 105;
int d[N];
struct node{
string st;
int dis;
bool operator < (const node p) const{
return dis > p.dis;
}
};
int Guass(string ss,string mir){
int ans = 0;
fi(i,0,sz(ss)-1){
if(ss[i] != mir[i]) ans++;
}
return --ans;
}
priority_queue<node> que;
void bfs(string ss,string mir){
que.push({ss,Guass(ss,mir)});
while(!que.empty()){
node p = que.top();
que.pop();
// cout << p << endl;
if(p.st == mir) {cout << "YES" << endl; return;}
uor[p.st]++; fi(i,0,sz(p.st) - 1){
if(i + d[i] < sz(p.st)){
string temp = p.st;
swap(temp[i],temp[i+d[i]]);
// cout << temp << endl;
if(!uor[temp])
que.push({temp,Guass(temp,mir)+1+p.dis});
}
if(i - d[i] >= 0){
string temp = p.st;
swap(temp[i],temp[i - d[i]]);
if(!uor[temp])
que.push({temp,Guass(temp,mir)+1+p.dis});
}
} }
cout << "NO" << endl;
return;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
int n;
cin >> n;
string Balloon;
string mir; fi(i,1,n){
char c;
cin >> c;
Balloon.push_back(c);
}
fi(i,1,n) mir.push_back((char)(i+48)); fi(i,0,n-1) cin >> d[i]; bfs(mir,Balloon);
return 0;
}

正解1图论

#include<iostream>
#include<utility>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
const int N = 105;
int d[N];
int Balloon[N];
int g[N][N];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
int n;
cin >> n;
fi(i,1,n) cin >> Balloon[i];
fi(i,1,n) cin >> d[i]; fi(i,1,n) fi(j,1,n) g[i][j] = 0x3f3f3f3f;
fi(i,1,n) g[i][i] = 0; fi(i,1,n){
if(i + d[i] <= n)
g[i][i+d[i]] = g[i+d[i]][i] = 1;
if(i - d[i] >= 1)
g[i][i-d[i]] = g[i-d[i]][i] = 1;
} fi(k,1,n) fi(i,1,n) fi(j,1,n)
g[i][j] = min(g[i][k] + g[k][j],g[i][j]); fi(i,1,n){
if(g[i][Balloon[i]] == 0x3f3f3f3f) {
cout << "NO" << endl;
return 0;
}
}
cout << "YES" << endl;
return 0;
}

正解2并查集

用并查集实现的话相当于一个可达性问题,根据之前图论的思路。

时间复杂度为O(nlogn)

#include<iostream>
#include<utility>
using namespace std;
typedef long long ll;
#define fi(i,a,b) for(int i = a; i <= b; ++i)
#define fr(i,a,b) for(int i = a; i >= b; --i)
#define x first
#define y second
#define sz(x) ((int)(x).size())
#define pb push_back
using pii = pair<int,int>;
//#define DEBUG
const int N = 105;
int Balloon[N];
int d[N];
int f[N];
int find(int x){
return f[x] == x ? x: f[x] = find(f[x]);
}
void combin(int x,int y){
f[find(x)] = f[find(y)];
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
#ifdef DEBUG
//freopen(D:\in.txt,r,stdin);
#endif
int n;
cin >> n;
fi(i,1,n) cin >> Balloon[i];
fi(i,1,n) cin >> d[i];
fi(i,1,n) f[i] = i;
fi(i,1,n){
if(i + d[i] <= n) combin(i,i+d[i]);
if(i - d[i] > 0) combin(i,i-d[i]);
}
fi(i,1,n){
if(find(i) != find(Balloon[i]))
{
cout << "NO" << endl;
return 0;
}
}
cout << "YES" << endl;
return 0;
}

Acwing周赛分享的更多相关文章

  1. AcWing周赛43

    AcWing周赛43 题源:https://www.acwing.com/activity/content/1233/ 4314. 三元组 直接暴力做就是了,我一开始还在找规律..悲 我滴代码 #in ...

  2. AcWing周赛44

    周赛44 4317. 不同正整数的个数 link:https://www.acwing.com/problem/content/4320/ 我直接set #include <iostream&g ...

  3. 【AcWing】周赛

    A.糖果 题目链接 链接 题目描述 给定三个正整数 a,b,c. 请计算 ⌊a+b+c2⌋,即 a,b,c 相加的和除以 2 再下取整的结果. 输入格式 第一行包含整数 T,表示共有 T 组测试数据. ...

  4. 【AcWing】第 62 场周赛 【2022.07.30】

    AcWing 4500. 三个元素 题目描述 给定一个长度为 \(n\) 的数组 \(r\_1,r\_2,-,r\_n\). 请你找到其中的三个元素 \(r\_a,r\_b,r\_c\),使得 \(r ...

  5. AcWing第85场周赛

    这场周赛是手速局hh 死或生 某国正在以投票的方式决定 2 名死刑犯(编号 1∼2)的生死. 共有 n 组人员(编号 1∼n)参与投票,每组 10 人. 每组成员只参与一名死刑犯的投票,其中第 i 组 ...

  6. AcWing 第11场周赛题解

    计算abc 首先 \(0<=a<=b<=c\) 会随机给出 \(a+b,a+c,b+c,a+b+c\)的值 因为\(a,b,c\)都为正整数,所以\(a+b+c\)一定为最大值 然后 ...

  7. AcWing第78场周赛

    今天想起来了,就补一下吧~ 第一题 商品分类 货架中摆放着 n 件商品,每件商品都有两个属性:名称和产地. 当且仅当两件商品的名称和产地都相同时,两件商品才视为同一种商品. 请你统计,货架中一共有多少 ...

  8. CCPC比赛与算法学习的个人分享

    大赛简介 中国大学生程序设计竞赛(China Collegiate Programming Contest,简称CCPC)是工业和信息化部教育与考试中心主办的 "强国杯"技术技能大 ...

  9. LeetCode 周赛 338,贪心 / 埃氏筛 / 欧氏线性筛 / 前缀和 / 二分查找 / 拓扑排序

    本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 大家好,我是小彭. 上周末是 LeetCode 第 338 场周赛,你参加了吗?这场周赛覆盖的知识点很多,第 ...

  10. .net点选验证码实现思路分享

    哈哈好久没冒泡了,最进看见点选验证码有点意思,所以想自己写一个. 先上效果图 如果你被这个效果吸引了就请继续看下去. 贴代码前先说点思路: 1.要有一个汉字库,并按字形分类.(我在数据库里是安部首分类 ...

随机推荐

  1. C++:面向对象

    文章目录 继承与多态 继承 继承的构造与析构 虚继承 多态 ❀虚/纯虚函数❀ 虚析构/纯虚析构 对象的生命周期 实例化对象 构造函数与析构函数 拷贝构造函数 防止拷贝 总结 深拷贝与浅拷贝 初始化列表 ...

  2. 如何使用 JavaScript 获取当前页面帧率 FPS

    可以通过计算每秒 window.requestAnimationFrame 的调用频率来做为 FPS 值.它接收一个回调函数,该回调函数会在浏览器下一次重绘之前执行.所以只要我们循环调用并记录单位时间 ...

  3. Oracle批量插入和更新

    一.驱动.使用Oracle.ManagedDataAccess.Client 二.原理.利用OracleCommand的ArrayBindCount属性设置批量大小. 三.实现 函数使用的实体是efc ...

  4. uniapp video组件全屏导致页面横竖错乱问题

    uniapp video组件全屏导致页面横竖错乱问题 背景介绍 使用 video组件做一个视频播放功能,不全屏的情况正常.在苹果手机上全屏后,点击左上角退出全屏,页面出现问题如下图问题,主要系统iOS ...

  5. 图片GPS度分秒转换经纬度

    图片位置信息转化经纬度 1 public static String strToLatOrLng(String str) { 2 int i = str.lastIndexOf("°&quo ...

  6. Vue3.0极速入门(一) - 环境安装&新建项目

    Vue介绍 Vue.js 是什么 Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只 ...

  7. kubernetes自动扩缩容[HPA控制器 horizontal pod autoscaler]

    kubernetes自动扩缩容[HPA控制器 horizontal pod autoscaler] #查看当前hpa控制器版本: [root@k8s-master01 ~]# kubectl get ...

  8. 搭建高可用k8s

    搭建k8s高可用 高可用只针对于api-server,需要用到nginx + keepalived,nginx提供4层负载,keepalived提供vip(虚拟IP) 系统采用openEuler 22 ...

  9. vue导航固定 吸顶效果

    吸顶效果 如何得到滚动条滚动的距离,document.documentElement.scrollTop 通过onscroll事件来完成滚动事件监听,达到吸顶值后,进行样式更换

  10. kettle从入门到精通 第十五课 kettle 映射 (子转换)01

    1.kettle 里面的映射和java代码里面的封装是一个概念,就是将一个可复用的模块单独抽离为公共模块供其他模块引用,用到的步骤或者组件如下 2.构建子映射,子映射需要用到映射输入规范和映射输出规范 ...