比赛链接:Here

AcWing 3726. 调整数组

签到题

void solve() {
int n; cin >> n;
int x = 0, y = 1, c;
for (int i = 0; i < n; ++i) {
cin >> c, x |= c, y &= c;
}
cout << ((x ^ y) & 1 ? "NO\n" : "YES\n");
}

AcWing 3727. 乘方相加

如果将所有的 \(v_i\) 用 kk 进制表示,则第 \(i\) 次操作就相当于是在 \(v_i\) 的第 \(i\) 位上加一。

所以如果我们能得到 a,那么所有的 \(a_i\) 的第 \(k\) 位最多只能有一个是 \(1\)。

因此我们可以枚举 \(a\) 中所有数的第 \(i\) 位,对第 \(i\) 位上的数求和,若得到的值 \(>1\),则我们不能将 \(v\) 变成 \(a\)

  • \(\mathcal{O}(nlog\ a_i)\)
ll a[33];
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int _; for (cin >> _; _--;) {
int n, k;
cin >> n >> k;
for (int i = 0; i < n; ++i)cin >> a[i];
bool f = true;
for (int i = 0; i < 64 and f; ++i) {
int s = 0;
for (int j = 0; j < n; ++j) s += a[j] % k, a[j] /= k;
f &= s < 2;
}
cout << (f ? "YES\n" : "NO\n");
}
}

AcWing 3728. 城市通电

原题来自:https://codeforces.com/problemset/problem/1245/D

将题目中所有发电站和电线看成一张无向图,搭建电线看成是将图上两个点连接起来。

根据题意,最终得到的图是若干个连通块,每个连通块中有一个点建立发电站。

考虑新建一个 \(0\) 点,向 \(1∼n\) 中所有点 \(u\) 连一条长度是 \(c_u\) 的边。

那么在某个点 \(u\) 建立发电站就可以看成选择 \(0→u\) 的这条边。

那么我们要做的,就转化为:给定一张无向图,选若干条边,使得图连通。

而这恰是最小生成树。因此我们只需建图并求最小生成树即可。

时间复杂度

这里我用的是 \(kruskal\) 算法求最小生成树,时间复杂度为\(O(n^2log⁡n)\)。

更优的算法是用 \(prim\) 算法,时间复杂度为\(O(n^2)\),但用 \(prim\) 算法不太好求具体方案,故这里选择 \(kruskal\)。

#include <bits/stdc++.h>
using namespace std;
using LL = long long;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin >> n;
vector<int> x(n), y(n), k(n);
for (int i = 0; i < n; ++i)
cin >> x[i] >> y[i];
vector<LL> c(n);
for (int i = 0; i < n; ++i)
cin >> c[i];
for (int i = 0; i < n; ++i)
cin >> k[i];
vector<bool> visited(n);
vector<int> parent(n, -1);
LL total = 0;
vector<int> sta;
for (int i = 0; i < n; ++i) {
int u = -1;
for (int j = 0; j < n; ++j)
if (!visited[j] && (u == -1 || c[j] < c[u]))
u = j;
visited[u] = true;
total += c[u];
if (parent[u] == -1)
sta.push_back(u);
for (int j = 0; j < n; ++j) {
if (!visited[j]) {
LL cost = 1LL * (k[u] + k[j]) * (abs(x[u] - x[j]) + abs(y[u] - y[j]));
if (cost < c[j]) {
c[j] = cost;
parent[j] = u;
}
}
}
}
cout << total << "\n";
cout << sta.size() << "\n";
for (int i : sta)
cout << i + 1 << "\n";
cout << n - sta.size() << "\n";
for (int i = 0; i < n; ++i)
if (parent[i] != -1)
cout << i + 1 << " " << parent[i] + 1 << "\n";
return 0;
}

AcWing 第五场周赛的更多相关文章

  1. AcWing第85场周赛

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

  2. 第五场周赛(字符串卡常个人Rank赛)——题解

    本次题目因为比较简单,除了个别题目,其余题目我只写一个思路不再贴代码. 先是Div.2的题解 A题奇怪的优化,把递归函数改成2*fun(...)即可,其实看懂程序也不难,就是求a*2b: B题你会st ...

  3. AcWing 第11场周赛题解

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

  4. AcWing第78场周赛

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

  5. Leetcode第 217 场周赛(思维量比较大)

    Leetcode第 217 场周赛 比赛链接:点这里 做完前两题我就知道今天的竞赛我已经结束了 这场比赛思维量还是比较大的. 1673. 找出最具竞争力的子序列 题目 给你一个整数数组 nums 和一 ...

  6. HDU(4528),BFS,2013腾讯编程马拉松初赛第五场(3月25日)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=4528 小明系列故事——捉迷藏 Time Limit: 500/200 MS (Java/O ...

  7. noi.ac 第五场第六场

    t1应该比较水所以我都没看 感觉从思路上来说都不难(比牛客网这可简单多了吧) 第五场 t2: 比较套路的dp f[i]表示考虑前i个数,第i个满足f[i]=i的最大个数 i能从j转移需要满足 j< ...

  8. # NOI.AC省选赛 第五场T1 子集,与&最大值

    NOI.AC省选赛 第五场T1 A. Mas的童年 题目链接 http://noi.ac/problem/309 思路 0x00 \(n^2\)的暴力挺简单的. ans=max(ans,xor[j-1 ...

  9. NOI.AC NOIP模拟赛 第五场 游记

    NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...

  10. 牛客网暑期ACM多校训练营(第五场):F - take

    链接:牛客网暑期ACM多校训练营(第五场):F - take 题意: Kanade有n个盒子,第i个盒子有p [i]概率有一个d [i]大小的钻石. 起初,Kanade有一颗0号钻石.她将从第1到第n ...

随机推荐

  1. UNI-APP之微信小程序转H5

    开始 最近有个需求,需要将微信小程序中一些页面和功能改成h5,这次功能开发的时间有点紧,而且重新写一套有点来不及.考虑到微信小程序与uni-app有着一些共通之处,所以打算直接转成uni-app.un ...

  2. dbeaver软件的使用

    dbeaver软件的使用 一.dbeaver简介: dbeaver是免费和开源(GPL)为开发人员和数据库管理员通用数据库工具. DBeaver [1] 是一个通用的数据库管理工具和 SQL 客户端, ...

  3. Ubuntu 18.04替换默认软件源

    安装Ubuntu 18.04后,默认源在国外,可以替换为国内的源以提升访问速度 参考https://mirrors.ustc.edu.cn/repogen/ sudo vi /etc/apt/sour ...

  4. MySQL-防止误删除的方案就是删除,看不见岂不就是删除了吗,所以就是把它隐藏起来。

    版权声明:原创作品,谢绝转载!否则将追究法律责任. ----- 作者:kirin 伪删除: 用update替代delete 1.添加状态列 ALTER TABLE student2 ADD state ...

  5. 用友U8和旺店通·企业奇门单据接口对接

    用友U8和旺店通·企业奇门单据接口对接 对接系统旺店通·企业奇门 旺店通是北京掌上先机网络科技有限公司旗下品牌,国内的零售云服务提供商,基于云计算SaaS服务模式,以体系化解决方案,助力零售企业数字化 ...

  6. STM32外设:信号转换器 ADC、DAC

    主要外设: ADC:Analog to Digital Converter 模数转换器 DAC:Digital to Analog Converter 数模转换器 ADC_IN` 主要功能:测外部引脚 ...

  7. Miller_Rabin 学习笔记

    费马小定理:对于任意一个质数满足:\(a^{p-1}\equiv1\pmod p\) 二次探测:对于任意一个奇质数满足:\(x^2\equiv1\pmod p\) 的解为 \(x=1\) 或 \(x= ...

  8. Helm Chart 部署 Redis 的完美指南

    目录 一.Helm介绍 二.安装Helm 三.配置Helm的repository 四.部署chart(以部署redis为例) 1. 搜索chart 2. 拉取chart 3. 修改values.yam ...

  9. Net 高级调试之十四:线程同步的基础知识和常见的同步原语

    一.介绍 今天是<Net 高级调试>的第十四篇文章,这篇文章我们主要介绍和线程相关的内容,当然不是教你如何去写多线程,更不会介绍多线程的使用方法和API,今天,我们主要讲一下锁,一说到多线 ...

  10. Codeforces Round #426 (Div. 2) problem B

    B. The Festive Evening time limit per test 1 second memory limit per test 256 megabytes input standa ...