AtCoder Beginner Contest 178
比赛链接:https://atcoder.jp/contests/abc178/tasks
A - not
题意
给出一个整数 $0 \le x \le 1$,如果 $x$ 是 $0$ 就输出 $1$,如果 $x$ 是 $1$ 就输出 $0$ 。
题解
输出 $x \oplus 1$ 或 $!x$ 均可。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int x;
cin >> x;
cout << (x ^ 1) << "\n";
return 0;
}
B - Product Max
题意
给出 $a,b,c,d$,问 $x \times y$ 的最大值。($-10^9 \leq a \leq x \leq b \leq 10^9$,$-10^9 \leq c \leq y \leq d \leq 10^9$)
题解
相似题目:CF1406B,枚举四个端点之积即可。
简单解释一下:
- 当 $x,y$ 均为正数或正端点之积较大,此时答案为 $b \times d$
- 当 $x,y$ 均为负数或负端点之积较大,此时答案为 $a \times c$
- 当 $x,y$ 一方为正数一方为负数,此时答案为 $a \times d$ 或 $b \times c$
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
long long a, b, c, d;
cin >> a >> b >> c >> d;
cout << max({a * c, a * d, b * c, b * d}) << "\n";
return 0;
}
C - Ubiquity
题意
找出满足以下条件的长为 $n$ 的不同序列的个数:
- $0 \le a_i \le 9$
- 序列中至少有一个 $a_i = 0$
- 序列中至少有一个 $a_i = 9$
答案对 $10^9+7$ 取模。
题解
总的序列个数为 $10^n$,
不含 $0$ 的序列个数为 $9^n$,
不含 $9$ 的序列个数为 $9^n$,
不含 $0$ 和 $9$ 的序列个数为 $8^n$,
根据容斥原理,答案即 $10^n - 2 \times 9^n + 8 ^ n$ 。
代码
#include <bits/stdc++.h>
using namespace std;
const int MOD = 1e9 + 7; int binpow(int a, int b) {
int res = 1;
while (b) {
if (b & 1) res = 1LL * res * a % MOD;
a = 1LL * a * a % MOD;
b >>= 1;
}
return res;
} int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin >> n;
cout << (0LL + binpow(10, n) - 2 * binpow(9, n) + binpow(8, n) + 2 * MOD) % MOD << "\n";
return 0;
}
D - Redistribution
题意
给出一个正整数 $s$,问有多少序列满足 $a_i \ge 3$,且序列和为 $s$,答案对 $10^9+7$ 取模。
题解一
设 $dp_i$ 为序列和为 $i$ 的序列个数。
初始时只有序列为空这一种情况,即 $dp_0 = 1$,之后每次向序列中添加大于等于 $3$ 的元素,最终答案即 $dp_s$ 。
代码
#include <bits/stdc++.h>
using namespace std;
constexpr int MOD = 1e9 + 7;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int s;
cin >> s;
vector<int> dp(2020);
dp[0] = 1;
for (int i = 0; i <= s; i++) {
for (int j = 3; i + j <= s; j++) {
(dp[i + j] += dp[i]) %= MOD;
}
}
cout << dp[s] << "\n";
return 0;
}
题解二
$ dp_i = \sum\limits_{j=0}^{i-3}dp_j $
$ dp_{i-1} = \sum\limits_{j=0}^{i-4}dp_j $
$ dp_i = \sum\limits_{j=0}^{i-3}dp_j = \sum\limits_{j=0}^{i-4}dp_j + dp_{i-3} = dp_{i-1} + dp_{i - 3} $
代码
#include <bits/stdc++.h>
using namespace std;
constexpr int MOD = 1e9 + 7;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int s;
cin >> s;
vector<int> dp(2020);
dp[0] = 1;
for (int i = 3; i <= s; i++)
dp[i] = (dp[i - 1] + dp[i - 3]) % MOD;
cout << dp[s] << "\n";
return 0;
}
题解三
已知序列和为 $s$ ,枚举序列的长度 $i$ 。
因为每个元素都大于等于 $3$,假设每个元素都为 $3$ ,可以将多出来的 $ s-3*i$ 个 $1$ 看作 $n$ 个相同的小球放入 $m=i$ 个可为空的相同的盒子中。
此时即转化为组合数学十二路问题中的 $ULA$ 问题,答案即 $\sum_{i = 1}^{\lfloor \frac{s}{3} \rfloor}C_{n+m - 1}^{m - 1}$ 。
代码
#include <bits/stdc++.h>
using namespace std;
constexpr int N = 1e6 + 100;
constexpr int MOD = 1e9 + 7; int fac[N], inv[N]; int binpow(int a, int b) {
int res = 1;
while (b) {
if (b & 1) res = 1LL * res * a % MOD;
a = 1LL * a * a % MOD;
b >>= 1;
}
return res;
} int C(int n, int m){
if(m < 0 or m > n) return 0;
return 1LL * fac[n] * inv[m] % MOD * inv[n - m] % MOD;
} void Init(){
fac[0] = 1;
for (int i = 1; i < N; i++) fac[i] = 1LL * fac[i - 1] * i % MOD;
inv[N - 1] = binpow(fac[N - 1], MOD - 2);
for (int i = N - 2; i >= 0; i--) inv[i] = 1LL * inv[i + 1] * (i + 1) % MOD;
} int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
Init();
int s;
cin >> s;
long long ans = 0;
for (int i = 1; i <= s / 3; i++) {
(ans += C(s - 3 * i + i - 1, i - 1)) %= MOD;
}
cout << ans << "\n";
return 0;
}
E - Dist Max
题意
给出 $n$ 个二维平面中的点,问两点间的最远曼哈顿距离。
题解
$(x_i,y_i), (x_j, y_j)$ 间的曼哈顿距离为 $|x_i-x_j| + |y_i-y_j|$ 。
假设 $x_i \ge x_j$,那么两点间的距离可能有两种情况:
- $(x_i-x_j) + (y_i-y_j)$,移项得:$(x_i+y_i) - (x_j+ y_j)$
- $(x_i-x_j) + (y_j-y_i)$,移项得:$(x_i-y_i) - (x_j- y_j)$
所以对于每个点的坐标 $(x,y)$,分别用两个数组存储 $x+y$ 和 $x-y$,然后取两个数组较大的最值差即可。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin >> n;
vector<int> a(n), b(n);
for (int i = 0; i < n; i++) {
int x, y;
cin >> x >> y;
a[i] = x + y;
b[i] = x - y;
}
sort(a.begin(), a.end());
sort(b.begin(), b.end());
cout << max(a.back() - a.front(), b.back() - b.front()) << "\n";
return 0;
}
F - Contrast
题意
给出两个非递减序列 $a$ 和 $b$,问能否重排 $b$ 使得 $a_i \ne b_i $ 。
题解
将序列 $b$ 反转,因为 $a$ 为非递减序,$b$ 为非递增序,所以序列中至多存在一段区间 $[l,r]$ 使得 $a_i = b_i = c$ 。
如果区间外的某个 $b_j$ 与区间内的 $b_i$ 调换后满足题意,那么 $a_j \ne b_i,\ b_j \ne a_i$,即 $a_j \ne c$ 且 $b_j \ne c$ 。
如果这样的 $b_j$ 个数小于区间长度则无解,否则输出调换后的序列 $b$ 即可。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n;
cin >> n;
vector<int> a(n), b(n);
for (int i = 0; i < n; i++)
cin >> a[i];
for (int i = 0; i < n; i++)
cin >> b[i];
reverse(b.begin(), b.end());
int c = -1;
for (int i = 0; i < n; i++) {
if (a[i] == b[i]) {
c = a[i];
break;
}
}
int l = n, r = -1;
for (int i = 0; i < n; i++) {
if (a[i] == c and b[i] == c) {
l = min(l, i);
r = max(r, i);
}
}
for (int i = 0; i < n; i++) {
if (a[i] != c and b[i] != c and l <= r) {
swap(b[i], b[l]);
++l;
}
}
if (l <= r) {
cout << "No" << "\n";
return 0;
}
cout << "Yes" << "\n";
for (int i = 0; i < n; i++) {
cout << b[i] << " \n"[i == n - 1];
}
return 0;
}
AtCoder Beginner Contest 178的更多相关文章
- AtCoder Beginner Contest 178 E - Dist Max 题解(推公式)
题目链接 题目大意 给你n个点(n<=2e5)要你求所有点中两个点最短的曼哈顿距离 曼哈顿距离定义为d(i,j)=|x1-x2|+|y1-y2|. 题目思路 想了很久也没有什么思路,其实就是一个 ...
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- AtCoder Beginner Contest 052
没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 136
AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】
AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...
- AtCoder Beginner Contest 064 D - Insertion
AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...
随机推荐
- #3使用html+css+js制作网页 番外篇 使用python flask 框架 (I)
#3使用html+css+js制作网页 番外篇 使用python flask 框架(I 第一部) 0. 本系列教程 1. 准备 a.python b. flask c. flask 环境安装 d. f ...
- 微信小程序项目转换为uni-app项目
一.它是谁? [miniprogram-to-uniapp]转换微信小程序"项目为uni-app项目.原则上混淆过的项目,也可以进转换,因为关键字丢失,不一定会完美. 二.它的原理是什么? ...
- Linux常用命令(df&dh)
在Linux下查看磁盘空间使用情况,最常使用的就是du和df了.然而两者还是有很大区别的,有时候其输出结果甚至非常悬殊. du的工作原理 du命令会对待统计文件逐个调用fstat这个系统调用,获取文件 ...
- HP(惠普)服务器 修复 Intelligent Provisioning(摘录)
摘录自:https://www.xxshell.com/1219.html 我们在给惠普服务器安装操作系统和配置RAID最常用的就是通过F10(Intelligent Provisioning)进行, ...
- 一网打尽,一文讲通虚拟机VirtualBox及Linux使用
本文将从虚拟机的选择.安装.Linux系统安装.SSH客户端工具使用四个方面来详细介绍Linux系统在虚拟机下的安装及使用方法,为你在虚拟机下正常使用Linux保驾护航. 1.虚拟机的选择 在讲虚拟机 ...
- LeetCode844 比较含退格的字符串
题目描述: 给定 S 和 T 两个字符串,当它们分别被输入到空白的文本编辑器后,判断二者是否相等,并返回结果. # 代表退格字符. 示例 1: 输入:S = "ab#c", T = ...
- CAN总线采样点测试
采样点是什么? 采样点是接受节点判断信号逻辑的位置,CAN通讯属于异步通讯.需要通过不断的重新同步才能保证收发节点的采样准确. 若采样点太靠前,则因为线缆原因,DUT外发报文尚未稳定,容易发生采样错误 ...
- 创建mysql帐户
CREATE USER 'username'@'host' IDENTIFIED BY 'password';
- 爬虫-使用lxml解析html数据
使用lxml之前,我们首先要会使用XPath.利用XPath,就可以将html文档当做xml文档去进行处理解析了. 一.XPath的简单使用: XPath (XML Path Language) 是一 ...
- Flutter 自定义列表以及本地图片引用
前言 上篇关于Flutter的文章总结了下标签+导航的项目模式的搭建,具体的有需要的可以去看看Flutter分类的文章,这篇文章我们简单的总结一下关于Flutter本地文件引用以及简单的自定义List ...