惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

SecWiki News
SecWiki News
I
InfoQ
The Cloudflare Blog
人人都是产品经理
人人都是产品经理
博客园 - Franky
T
Tailwind CSS Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
量子位
博客园_首页
罗磊的独立博客
V
V2EX
李成银的技术随笔
大猫的无限游戏
大猫的无限游戏
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
T
True Tiger Recordings
Vercel News
Vercel News
Cyberwarzone
Cyberwarzone
Cisco Talos Blog
Cisco Talos Blog
F
Fox-IT International blog
D
Darknet – Hacking Tools, Hacker News & Cyber Security
M
Microsoft Research Blog - Microsoft Research
Know Your Adversary
Know Your Adversary
爱范儿
爱范儿
The Register - Security
The Register - Security
G
Google Developers Blog
The Hacker News
The Hacker News
Malwarebytes
Malwarebytes
S
Securelist
博客园 - 三生石上(FineUI控件)
Jina AI
Jina AI
T
Threat Research - Cisco Blogs
T
The Exploit Database - CXSecurity.com
S
SegmentFault 最新的问题
博客园 - 叶小钗
F
Fortinet All Blogs
Apple Machine Learning Research
Apple Machine Learning Research
宝玉的分享
宝玉的分享
博客园 - 聂微东
T
Threatpost
博客园 - 【当耐特】
D
Docker
P
Privacy & Cybersecurity Law Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
G
GRAHAM CLULEY
V
Visual Studio Blog
C
Cisco Blogs
IT之家
IT之家
S
Security Archives - TechRepublic
Latest news
Latest news
阮一峰的网络日志
阮一峰的网络日志

Shiroha白羽的博客

Codeforces Round 1089 (Div. 2) Codeforces Round 1079 (Div. 2) 2025 总结 The Burrows-Wheeler Transform 块排序压缩算法 Summer Pockets 动画完结 香港银行开卡记-1 【转载】Rust 中常见的有关生命周期的误解 Codeforces Round 972 (Div. 2) 《黑神话:悟空》游玩评测 Golang 踩坑 —— interface 为参数的时候传 nil 指针 用 magic 变量解决 UAF 问题 Codeforces Round 942 (Div. 2) Codeforces Round 941 (Div. 2) Codeforces Round 940 (Div. 2) and CodeCraft-23 日本旅游杂记-东京篇 Codeforces Round 939 (Div. 2) Codeforces Round 928 (Div. 4) Codeforces Round 927 (Div. 3) Codeforces Round 926 (Div. 2) Codeforces Round 925 (Div. 3) Codeforces Round 924 (Div. 2) Codeforces Round 923 (Div. 3) Codeforces Round 922 (Div. 2) Codeforces Round 921 (Div. 2) Educational Codeforces Round 161 (Rated for Div. 2) Codeforces Round 920 (Div. 3) Codeforces Round 919 (Div. 2) Hello 2024 Good Bye 2023 Codeforces Round 918 (Div. 4) 个人备份的常用 macOS 清理命令 Codeforces Round 917 (Div. 2) Pinely Round 3 (Div. 1 + Div. 2) Educational Codeforces Round 160 (Rated for Div. 2) Codeforces Round 915 (Div. 2) Codeforces Round 914 (Div. 2) Codeforces Round 913 (Div. 3) Educational Codeforces Round 159 (Rated for Div. 2) Codeforces Round 912 (Div. 2) Codeforces Round 911 (Div. 2) CodeTON Round 7 (Div. 1 + Div. 2, Rated, Prizes!) Educational Codeforces Round 158 (Rated for Div. 2) Codeforces Round 910 (Div. 2) Codeforces Round 909 (Div. 3) Codeforces Round 908 (Div. 2) Educational Codeforces Round 157 (Rated for Div. 2) C++自定义的字面量 Codeforces Round 907 (Div. 2) Codeforces Round 916 (Div. 3) 关于 LRU map 的一些灵感 2023 杭州站 ICPC 现场赛 反复横跳的 Clang-Tidy(cert-dcl21-cpp) Codeforces Round 906 (Div. 2) 一段奇怪的 CPP 代码 Codeforces Round 905 (Div. 3) Codeforces Round 904 (Div. 2) Codeforces Round 903 (Div. 3) Educational Codeforces Round 156 (Rated for Div. 2) Codeforces Round 902 (Div. 2, based on COMPFEST 15 - Final Round) Codeforces Round 901 (Div. 2) Codeforces Round 900 (Div. 3) Codeforces Round 899 (Div. 2) Educational Codeforces Round#155 (Div. 2) Codeforces Round 898 (Div. 4) CodeTON Round 6 (Div. 2) Codeforces Round 897 (Div. 2) Codeforces Round 896 (Div. 2) Codeforces Round 887 (Div. 2) 左值-右值-将亡值 Educational Codeforces Round#154 (Div. 2) Pinely Round 2 (Div. 1 + Div. 2) Harbour.Space Scholarship Contest 2023-2024 (Div. 1 + Div. 2) Codeforces Round 894 (Div. 3) Codeforces Round 888 (Div. 3) Educational Codeforces Round#153 (Div. 2) Codeforces Round 893 (Div. 2) OTPAUTH,两步验证中的通用协议 Codeforces Round 892 (Div. 2) Codeforces Round 891 (Div. 3) Codeforces Round 890 (Div. 2) Educational Codeforces Round#152 (Div. 2) Codeforces Round#889 (Div. 2) Java Script 的 null 和 undefined 随想 记一次 SQL LEFT JOIN 没有得到预期结果的错误 Codeforces Round#789(Div. 2) GCC/G++ 预编译头性能优化 使用 Junit5 和 Mockito 实现 SpringBoot 的单元测试最优美的解决方案 centOS 防火墙 docker-compse 的问题 Gitbook 安装出错 macOS 更新后导致 sdk 丢失问题 Java 生成验证码 Captcha C++ 模版可变参数列表传递给 C 的 va_list 可变参数列表 GitHub 下载的 zip 代码如何与原仓库再次建立连接 2021年浙江工商大学新生赛题解 Dockerfile 中下载 JDK8 Mac 使用带 python 的 vim Mac 截图唤起速度慢 C++ 语言实现动态变化的线程池 Strassen算法代码 Codeforces Round#744 (Div. 3)
Codeforces Round 895 (Div. 3)
2023-09-08 · via Shiroha白羽的博客

A. Two Vessels

大致题意

有 A,B 两个水池,用大小为 $c$ 的勺子舀,最少需要几次才能让这两个水池相同

思路

简单题,每次变化 $2c$,不要求平均数,不然精度不好算

AC code

1
2
3
4
5
6
7
8
9
10
void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int a, b, c;
cin >> a >> b >> c;
int diff = abs(a - b);
cout << (diff + 2 * c - 1) / (2 * c) << endl;
}
}

B. The Corridor or There and Back Again

大致题意

有一条射线,射线上有一些点有夹子,夹子会在人经过后 $x$ 秒触发,问从顶点出发,然后折返,问最远可以到哪里

思路

也是简单题,每个夹子就意味着单独的最远可达距离,然后取最小就行了

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int n;
cin >> n;
int ans = INT_MAX;
for (int i = 0; i < n; ++i) {
int a, b;
cin >> a >> b;
ans = min(ans, a + (b - 1) / 2);
}
cout << ans << endl;
}
}

C. Non-coprime Split

大致题意

给出 $[l, r]$ 这个区间,目的找到两个值 $a, b$,满足

  • $a + b \in [l, r]$
  • $gcd(a, b) \neq 1$

思路

第一反应就是偶数,毕竟任意两个偶数很容易达到,而且可以足够小,只要 $[l, r]$ 中存在偶数区间即可。当然,同时 $r \geq 4$,否则肯定没戏

如果还不行怎么办,那此时必然满足 $l = r, r \space mod \space 2 == 1$。这个时候,反正也只有一个数可以选了,强行找因子吧,找不到就算失败

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int l, r;
cin >> l >> r;
if (r < 4) {
cout << -1 << endl;
continue;
}
if (l != r || r % 2 == 0) {
cout << 2 << ' ' << ((r >> 1) << 1) - 2 << endl;
continue;
}
int mid = (int) sqrt(r) + 10;
int gcd = -1;
for (int i = 2; i <= mid; ++i) {
if (r - i <= 0) break;
if (r % i == 0) {
gcd = i;
break;
}
}
if (gcd == -1) {
cout << -1 << endl;
} else {
cout << gcd << ' ' << r - gcd << endl;
}
}
}

D. Plus Minus Permutation

大致题意

给定 $n, x, y$,你需要找到一个 $n$ 的排列,满足

$$((p_{1x}+p_{2x}+p_{3x}+ \dots + p_{\left \lfloor \frac{n}{x} \right \rfloor x}) - (p_{1y}+p_{2y}+p_{3y}+ \dots + p_{\left \lfloor \frac{n}{y} \right \rfloor y})$$

尽可能大,问最终结果是

思路

计算出 $x$ 单独占了几个,$y$ 单独占了几个,然后把大数给 $x$,小数给 $y$ 即可

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#define int long long

void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int n, x, y;
cin >> n >> x >> y;
int g = gcd(x, y), l = (x * y) / g;
int cntL = n / l, cntX = n / x - cntL, cntY = n / y - cntL;
int sumX = (n + (n - cntX + 1)) * cntX / 2, sumY = (1 + cntY) * cntY / 2;
cout << sumX - sumY << endl;
}
}

E. Data Structures Fan

大致题意

这题实在不想写题意了,已经把线段树这三个字拍脸上了

思路

维护两个值即可,为 $0$ 的异或和,为 $1$ 的异或和,然后每次改就是交换这两个值

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
const int N = 1e5 + 10;

struct SegTree {

int cnt[2][N << 1];
bool lazy[N << 1];

inline int static get(int l, int r) {
return (l + r) | (l != r);
}

inline void up(int l, int r) {
int mid = (l + r) >> 1;
cnt[0][get(l, r)] = cnt[0][get(l, mid)] ^ cnt[0][get(mid + 1, r)];
cnt[1][get(l, r)] = cnt[1][get(l, mid)] ^ cnt[1][get(mid + 1, r)];
}

void build(int l, int r) { // NOLINT(*-no-recursion)
lazy[get(l, r)] = false;
if (l == r) {
return;
}
int mid = (l + r) >> 1;
build(l, mid);
build(mid + 1, r);
up(l, r);
}

inline void push(int l, int r) {
int k = get(l, r);
if (lazy[k]) {
int mid = (l + r) >> 1;
int left = get(l, mid), right = get(mid + 1, r);
swap(cnt[0][left], cnt[1][left]);
swap(cnt[0][right], cnt[1][right]);
lazy[left] = !lazy[left];
lazy[right] = !lazy[right];
lazy[k] = false;
}
}

void update(int l, int r, int x, int y) { // NOLINT(*-no-recursion)
if (l == x && y == r) {
swap(cnt[0][get(l, r)], cnt[1][get(l, r)]);
lazy[get(l, r)] = !lazy[get(l, r)];
return;
}
push(l, r);
int mid = (l + r) >> 1;
if (y <= mid) {
update(l, mid, x, y);
} else if (x > mid) {
update(mid + 1, r, x, y);
} else {
update(l, mid, x, mid);
update(mid + 1, r, mid + 1, y);
}
up(l, r);
}

int query(int l, int r, int x, int y, int p) { // NOLINT(*-no-recursion)
if (l == x && y == r) {
return cnt[p][get(l, r)];
}
push(l, r);
int mid = (l + r) >> 1;
if (y <= mid) {
return query(l, mid, x, y, p);
} else if (x > mid) {
return query(mid + 1, r, x, y, p);
} else {
return query(l, mid, x, mid, p) ^ query(mid + 1, r, mid + 1, y, p);
}
}
} seg;

void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int n;
cin >> n;
for (int i = 1; i <= n; ++i) {
cin >> seg.cnt[0][SegTree::get(i, i)];
seg.cnt[1][SegTree::get(i, i)] = 0;
}
string str;
str.reserve(n);
cin >> str;
for (int i = 0; i < n; ++i)
if (str[i] == '1')
swap(seg.cnt[0][SegTree::get(i + 1, i + 1)], seg.cnt[1][SegTree::get(i + 1, i + 1)]);
seg.build(1, n);

int q;
cin >> q;
for (int i = 0; i < q; ++i) {
int o;
cin >> o;
if (o == 1) {
int l, r;
cin >> l >> r;
seg.update(1, n, l, r);
} else {
int x;
cin >> x;
cout << seg.query(1, n, 1, n, x) << ' ';
}
}
cout << endl;
}
}

F. Selling a Menagerie

大致题意

你决定逐个出售动物园里的动物,每个动物都有其价格,出售可以获得对应价格。

每个动物都有其唯一害怕的动物,如果你出售的时候,其害怕的动物还没有被出售,那么你可以获得双倍的价格奖励

给出一个出售顺序,使得最终价值最高

思路

很明显是一个 dag 的拓扑排序问题。可惜的是,这个并不是 dag,是有环的。而每次解开一个环,就要消耗一定代价。

可以直接将原来拓扑用的入度改成代价,即所有指向(害怕)这个节点的价格之和,因为如果这个节点先被拓扑了,那么这些指向它的节点就拿不到双倍的价值了,即损失了他们价格之和的代价

然后搞个优先队列拓扑就好了

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#define int long long

void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
struct node {
int v, n;
};

int n;
cin >> n;
vector<int> cost(n);
vector<int> link(n);
vector<int> deg(n, 0);
for (int i = 0; i < n; ++i) {
int tmp;
cin >> tmp;
link[i] = tmp - 1;
}
for (auto &item: cost) cin >> item;
for (int i = 0; i < n; ++i) deg[link[i]] += cost[i];

vector<bool> visit(n, false);
priority_queue<pair<int, int>, vector<pair<int, int>>, greater<>> prq;
for (int i = 0; i < n; ++i) prq.emplace(deg[i], i);
while (!prq.empty()) {
auto cur = prq.top();
prq.pop();
if (visit[cur.second]) continue;
visit[cur.second] = true;
cout << cur.second + 1 << ' ';
int nxt = link[cur.second];
if (visit[nxt]) continue;
deg[nxt] -= cost[cur.second];
prq.emplace(deg[nxt], nxt);
}
cout << endl;
}
}

G. Replace With Product

大致题意

给你一个数组,允许你选择其中一段,将其换成这些值的乘积,问数组最大的和是多少。需要给出选择的那一段

思路

由于乘法的增长通常都会远大于求和,我们需要寻找一个临界点,使得 $\prod_{i=1}^n a_i \geq \sum_{i=1}^n a_i$,这样就可以无脑乘起来了

假定数组中只有两个值是 $> 1$ 的,为 $x, y$,那么可以得到

$$ \begin{align*} xy & \geq n+x+y-2 \\ & \geq n+2\sqrt{xy}-2 \\ let \space t & \rightarrow \sqrt{xy} \\ t^2-2t+1 & \geq n - 1 \\ t-1 & \geq \sqrt{n-1} \\ t & \geq \sqrt{n-1}+1 \\ xy & \geq n-1+2\sqrt{n-1}+1 \\ & \geq n+2\sqrt{n-1} \\ & \geq n+n-1+1 \\ & \geq 2n \end{align*} $$

所以只要对于 $xy > 2n$ 的情况,则可以无脑选尽可能全部的即可,因为相加一定不如相乘,当然,是尽可能,不是一定全部

那对于那些不满足的,可以得到 $\prod_{i=1}^n a_i < 2n$,这是一个很难达到的,假定有 $x$ 个数值不为 $1$ 的值,那么必然平均值为 $\sqrt[x]{2n}$,当 $x = 100$ 的时候,平均值就一定 $< 2$ 了,就意味着有 $1$ 的存在,那更不可能乘起来达到目标值了,所以此时非 $1$ 的值数量极少,可以暴力求解

AC code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#define int long long

void solve() {
int _;
cin >> _;
for (int ts = 0; ts < _; ++ts) {
int n;
cin >> n;
vector<int> data(n);
for (auto &item: data) cin >> item;
int tot = 1;
for (auto &item : data) {
tot *= item;
if (tot > 2 * n) break;
}

if (tot > 2 * n) {
// make 1 less
int l = 0, r = n - 1;
while (data[l] == 1) l++;
while (data[r] == 1) r--;
cout << l + 1 << ' ' << r + 1 << endl;
continue;
}

vector<int> not1;
for (int i = 0; i < n; ++i) if (data[i] != 1) not1.push_back(i);

if (not1.empty()) {
cout << 1 << ' ' << 1 << endl;
continue;
}

int mx = 0, l = 0, r = 0;
for (int i = 0; i < not1.size() - 1; ++i) {
int curP = data[not1[i]], curS = data[not1[i]] - 1;
for (int j = i + 1; j < not1.size(); ++j) {
curP *= data[not1[j]];
curS += data[not1[j]] - 1;
int realS = curS + not1[j] - not1[i] + 1;
if (mx < curP - realS) {
mx = curP - realS;
l = not1[i];
r = not1[j];
}
}
}
cout << l + 1 << ' ' << r + 1 << endl;
}
}