2021暑假训练赛1 基于Codeforce#479(div3)
A - Xor Sum
似乎是很明显的字典树问题(不会啊,最后搬了一个板子修修改改以后才过了
AcWing 相似题目:143. 最大异或对
最后得吐槽一下 memset
为什么能这么慢啊 Kora!
改手动初始化之后从 TLE 降到 500ms
const int MAXN = 100005;
int tire[MAXN * 32][2];
ll arr[MAXN * 32], s;
int n, m;
int pos = 1;
void insert(ll s) {
int root = 0;
for (int i = 31; i >= 0; i--) {
int x = (s >> i) & 1;
if (tire[root][x] == 0)
tire[root][x] = pos++;
root = tire[root][x];
}
arr[root] = s;
}
ll search(ll s) {
bool flag = false;
int root = 0;
for (int i = 31; i >= 0; i--) {
int x = (s >> i) & 1;
if (tire[root][!x]) root = tire[root][!x];
else root = tire[root][x];
}
return arr[root];
}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int T, Case = 1;
cin >> T;
while (T--) {
cin >> n >> m;
while (n--) {
cin >> s;
insert(s);
}
cout << "Case #" << Case++ << ":" << endl;
while (m--) {
cin >> s;
cout << search(s) << endl;
}
for (int i = 0; i < MAXN; ++i) arr[i] = 0;
for (int i = 0; i < MAXN; ++i) for (int j = 0; j < 2; ++j) tire[i][j] = 0;
}
return 0;
}
B - Wrong Subtraction (签到)
过于谨慎了,签到题情况都想全了还是自测半天数据。
\(k\) 不大,直接暴力模拟
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
ll n, k; cin >> n >> k;
for (int i = 1; i <= k; ++i) {
int t = n % 10;
if (t == 0) n /= 10;
else n--;
}
cout << n;
}
C - Two-gram
为什么会理解错题意啊?!!
子串必须由相邻的两个字符组成。
说明字串长度为 \(2\) 啊
关于 string
似乎只能 push_back 加入字符了,
直接写 t = s[i] + s[i + 1] 会乱码
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n; string s;
cin >> n >> s; n -= 1;
int cnt = 0; string t = "";
for (int i = 0; i < n; i++) {
int ccnt = 1;
for (int j = i + 1; j < n; j++)
if (s[j] == s[i] && s[j + 1] == s[i + 1])
ccnt++;
if (ccnt > cnt) {
cnt = ccnt;
string tmp;
tmp.push_back(s[i]), tmp.push_back(s[i + 1]);
t = tmp;
}
}
cout << t << endl;
return 0;
}
E - Divide by three, multiply by two
看样例发现一个规律 12 4 8 16
关于 3 的因子个数,如果因子个数多的放在前面,因子数相同的话将小值排前
因为题目保证一定存在符合题意的组合,那么这种写法一个可以
const int N = 1e2 + 10;
ll a[N];
ll fun(ll n) {
ll cnt = 0;
while (n % 3 == 0) {cnt += 1, n /= 3;}
return cnt;
}
bool cmp(ll x, ll y) { return fun(x) == fun(y) ? x < y : fun(x) > fun(y);}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n; cin >> n;
for (int i = 0; i < n; ++i) cin >> a[i];
sort(a, a + n, cmp);
for (int i = 0; i < n; ++i) cout << a[i] << " \n"[i == n - 1];
}
F - Cyclic Components
很可惜,这道题做出了就AK了。
关于 简单环,在上图中只有 $[7,10,16],[5,11,9,15] $ 两个环符合条件,
即环内每个点的度当且仅当为 \(2\)
那么我们存边和度再跑DFS即可
const int N = 2e5 + 10;
vector<int>e[N];
bool vis[N];
int flag ;
void dfs(int u) {
vis[u] = 1;
if (e[u].size() != 2) flag = 0; // 如果 环内度数不为 2 则标记置为 0
for (auto v : e[u]) {
if (vis[v]) continue;
dfs(v);
}
}
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n, m; cin >> n >> m;
for (int i = 1, u, v; i <= m; ++i) {
cin >> u >> v;
e[u].push_back(v);
e[v].push_back(u);
}
int ans = 0;
for (int i = 1; i <= n; ++i) {
if (vis[i]) continue;
flag = 1;
dfs(i);
ans += flag;
}
cout << ans;
}
G - Consecutive Subsequence
看完题目知道是一道最长上升子序列题,但普通的DP似乎处理不了,因为:序列是连续的。
所以 DP 转移方程应该写为 \(f_i = max(f_{i - 1} + 1,f_i)\)
- \(\mathcal{O}(n)\)
ll a[N];
map<ll, int>mp;
int len, lst, n;
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
cin >> n;
for (int i = 0; i < n; ++i) {
cin >> a[i];
int cnt = mp[a[i]] = mp[a[i] - 1] + 1;
if (cnt > len) len = cnt, lst = a[i];
}
int tmp = lst - len + 1;
cout << len << "\n";
for (int i = 0; i < n; ++i)
if (a[i] == tmp) {
cout << i + 1 << " ";
tmp += 1;
}
return 0;
}
2021暑假训练赛1 基于Codeforce#479(div3)的更多相关文章
- 哈理工2015 暑假训练赛 zoj 2976 Light Bulbs
MS Memory Limit:65536KB 64bit IO Format:%lld & %llu SubmitStatusid=14946">Practice ...
- 哈理工2015暑假训练赛 zoj 2078Phone Cell
Phone CellTime Limit:10000MS Memory Limit:32768KB 64bit IO Format:%lld & %llu SubmitStatus ...
- [置顶] 2013_CSUST暑假训练总结
2013-7-19 shu 新生训练赛:母函数[转换成了背包做的] shuacm 题目:http://acm.hdu.edu.cn/diy/contest_show.php?cid=20083总结:h ...
- 暑假训练round 3 题解
今天做题运气出奇的好,除了几处小错误调试之后忘记改掉了……最后还AK了……虽然题目不难,学长也说是福利局,但是对个人的鼓励作用还是挺大的……至此暑假训练就结束了,也算没有遗憾……. 题解如下: Pro ...
- 10.0.0.55_12-16训练赛部分writeup
0x1 - MISC MISC100 一张帅行的照片 目测是图片隐写,但是binwalk并没有出来,应该是对文件头进行了修改 010editor查看一下,发现在jpg文件尾之后还有大量的数据 而且在灰 ...
- Contest1592 - 2018-2019赛季多校联合新生训练赛第二场(部分题解)
Contest1592 - 2018-2019赛季多校联合新生训练赛第二场 D 10248 修建高楼(模拟优化) H 10252 组装玩具(贪心+二分) D 传送门 题干 题目描述 C 市有一条东西走 ...
- Contest1585 - 2018-2019赛季多校联合新生训练赛第一场(部分题解)
Contest1585 - 2018-2019赛季多校联合新生训练赛第一场 C 10187 查找特定的合数 D 10188 传话游戏 H 10192 扫雷游戏 C 传送门 题干: 题目描述 自然数中除 ...
- 7.30 正睿暑期集训营 A班训练赛
目录 2018.7.30 正睿暑期集训营 A班训练赛 T1 A.蔡老板分果子(Hash) T2 B.蔡老板送外卖(并查集 最小生成树) T3 C.蔡老板学数学(DP NTT) 考试代码 T2 T3 2 ...
- HDU6578 2019HDU多校训练赛第一场 1001 (dp)
HDU6578 2019HDU多校训练赛第一场 1001 (dp) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6578 题意: 你有n个空需要去填,有 ...
- HDU6579 2019HDU多校训练赛第一场1002 (线性基)
HDU6579 2019HDU多校训练赛第一场1002 (线性基) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题意: 两种操作 1.在序列末 ...
随机推荐
- 链表K个节点的组内逆序调整问题
链表K个节点的组内逆序调整问题 作者:Grey 原文地址: 博客园:链表K个节点的组内逆序调整问题 CSDN:链表K个节点的组内逆序调整问题 题目描述 LeetCode 25. Reverse Nod ...
- 电子元器件工厂的金蝶 ERP 与赛意 WMS 系统数据集成平台进行对接
项目背景 国内某晶振集成电路研发单位,涵盖从产品开发.设计.生产.销售.服务等各个环节.需要全面建成以ERP.WMS.BOM.PLM.DMS.SRM.OA 为核心的企业信息系统,支持研发.生产.营销. ...
- Why Microservices ?
微服务(Microservices)是一种软件架构设计风格,其中应用程序由一组小型.独立.自治的服务组成,这些服务共同工作以构建整体应用.每个服务都专注于一个特定的业务功能,可以独立部署.扩展和维护. ...
- 针对el-menu-item组件的警告Invalid event arguments: event validation failed for event "cli
现象: 解决办法: 加上index这个唯一标识,不然会有意想不到的问题
- 如何使用sharding-sphere完成读写分离和分库分表?
一.sharding-sphere配置读写分离 1.先搭建好一个MySQL的主从集群,可以参考[MySQL主从集群搭建] 2.在项目中导入相关依赖(记得刷新Maven) <!--读写分离--&g ...
- MySQL运维14-管理及监控工具Mycat-web的安装配置
一.Mycat-web介绍 Mycat-web(现改名为Mycat-eye)是对Mycat-server提供监控服务,通过JDBC连接对Mycat,MySQL监控,监控远程服务器的cpu,内存,网络, ...
- 华企盾DSC防泄密软件造成VS启动报目录错误
解决方法:找到安装路径下的Privateregistry.bin文件解密即可
- ElasticSearch之cat indices API
命令样例如下: curl -X GET "https://localhost:9200/_cat/indices?v=true&pretty" --cacert $ES_H ...
- 斯坦福 UE4 C++ ActionRoguelike游戏实例教程 10.5.作业五 为游戏添加一个积分系统,随机生成增益道具
斯坦福课程 UE4 C++ ActionRoguelike游戏实例教程 0.绪论 概述 本篇文章将解决作业五提出的问题,使用PlayerState,在原本游戏的基础上引入积分系统,实现击杀敌人得分,拾 ...
- Spring系列:基于注解的方式构建IOC
目录 一.搭建子模块spring6-ioc-annotation 二.添加配置类 三.使用注解定义 Bean 四.@Autowired注入 五.@Resource注入 六.全部代码 从 Java 5 ...