比赛链接:https://atcoder.jp/contests/abc171/tasks

A - αlphabet

题意

给出一个字母,如果为大写输出 'A',如果为小写输出 'a' 。

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
char c; cin >> c;
cout << (isupper(c) ? 'A' : 'a');
}

B - Mix Juice

题意

从 $n$ 个数中选出 $k$ 个数之和的最小值。

题解

对前 $k$ 小的元素求和即可。

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
int n, k; cin >> n >> k;
int a[n] = {};
for (int i = 0; i < n; i++)
cin >> a[i];
sort(a, a + n);
cout << accumulate(a, a + k, 0);
}

C - One Quadrillion and One Dalmatians

题意

把一个数字转化为字母,规则为 $[1,26]$ 对应 $[a,z]$,$[27,702]$ 对应 $[aa,zz] \dots $ 。

题解

转化为 $26$ 进制即可,需要注意每次取余前令 $n$ 减一来把 $[1,26]$ 映射到 $[0,25]$ 。

代码一

非递归实现:

#include <bits/stdc++.h>
using ll = long long;
using namespace std;
int main() {
ll n; cin >> n;
int bit[100] = {};
int p = 0;
while (n) {
bit[p++] = (--n) % 26;
n /= 26;
}
for (int i = p - 1; i >= 0; i--)
cout << char(bit[i] + 'a');
}

代码二

递归实现:

#include <bits/stdc++.h>
using ll = long long;
using namespace std; void solve(ll n) {
if (n < 26)
putchar(n + 'a');
else {
solve(n / 26 - 1);
putchar(n % 26 + 'a');
}
} int main() {
ll n; cin >> n;
solve(n - 1);
}

D - Replacing

题意

给出 $n$ 个数和 $q$ 次操作,每次操作将 $n$ 个数中值为 $b$ 的数替换为 $c$,计算每次操作后 $n$ 个数的和。

题解

先对 $n$ 个数求和,每次操作总和的变化为 $(c-b)cnt_b$,之后更新 $cnt_b$ 和 $cnt_c$ 即可。

代码

#include <bits/stdc++.h>
using ll = long long;
using namespace std;
int main() {
int n; cin >> n;
ll ans = 0;
map<int, int> cnt;
for (int i = 0; i < n; i++) {
int x; cin >> x;
ans += x, cnt[x]++;
}
int q; cin >> q;
for (int i = 0; i < q; i++) {
int b, c; cin >> b >> c;
ans += 1LL * (c - b) * cnt[b];
cout << ans << "\n";
cnt[c] += cnt[b], cnt[b] = 0;
}
}

E - Red Scarf

题意

给出 $n$ 个数,计算每个数外 $n - 1$ 个数的异或值。

题解

利用 $x \oplus x = 0$ 的特性,先对所有数求一次异或,然后再对每个数求一次异或从总的异或值中抵消掉即可。

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
int n; cin >> n;
int a[n] = {};
for (int i = 0; i < n; i++)
cin >> a[i];
int Xor = 0;
for (int i = 0; i < n; i++)
Xor ^= a[i];
for (int i = 0; i < n; i++)
cout << (Xor ^ a[i]) << ' ';
}

F - Strivore

题意

在一个小写字母串 $s$ 的任意位置插入一个小写字母 $k$ 次后可能得到多少不同的字符串。

题解

一个重要的结论是:答案与字符串 $s$ 无关,只与其长度有关,但是这个的证明想了一天也没有想明白。

那么可以将 $s$ 视为一个单一字母串,答案即 $\sum_{i = len_s}^{n} C_n^i \times 25^{n - i}$ 。

代码

#include <bits/stdc++.h>
using ll = long long;
using namespace std;
const int N = 2e6 + 10;
const int mod = 1e9 + 7; ll fac[N], inv[N]; ll binpow(ll a, ll b) {
ll res = 1;
while (b) {
if (b & 1) res = res * a % mod;
a = a * a % mod;
b >>= 1;
}
return res;
} void init() {
fac[0] = 1;
for (int i = 1; i < N; i++)
fac[i] = fac[i - 1] * i % mod;
inv[N - 1] = binpow(fac[N - 1], mod - 2);
for (int i = N - 2; i >= 0; i--)
inv[i] = inv[i + 1] * (i + 1) % mod;
} ll C(ll n, ll m) {
return fac[n] * inv[m] % mod * inv[n - m] % mod;
} int main() {
init();
int k; string s; cin >> k >> s;
int n = k + s.size();
ll ans = 0;
for (int i = s.size(); i <= n; i++)
ans += C(n, i) * binpow(25, n - i) % mod, ans %= mod;
cout << ans << "\n";
}

AtCoder Beginner Contest 171的更多相关文章

  1. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

  2. AtCoder Beginner Contest 052

    没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...

  3. AtCoder Beginner Contest 053 ABCD题

    A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...

  4. AtCoder Beginner Contest 136

    AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...

  5. AtCoder Beginner Contest 137 F

    AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...

  6. AtCoder Beginner Contest 076

    A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...

  7. AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】

    AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...

  8. AtCoder Beginner Contest 064 D - Insertion

    AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...

  9. AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】

    AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...

随机推荐

  1. springboot源码解析-管中窥豹系列之排序(五)

    一.前言 Springboot源码解析是一件大工程,逐行逐句的去研究代码,会很枯燥,也不容易坚持下去. 我们不追求大而全,而是试着每次去研究一个小知识点,最终聚沙成塔,这就是我们的springboot ...

  2. 【C++】《C++ Primer 》第十四章

    第十四章 重载运算与类型转换 一.基本概念 重载运算符是具有特殊名字的函数:由关键字operator和其后要定义的运算符号共同组成.也包含返回类型.参数列表以及函数体. 当一个重载的运算符是成员函数时 ...

  3. LeetCode150 逆波兰表达式求值

    根据逆波兰表示法,求表达式的值. 有效的运算符包括 +, -, *, / .每个运算对象可以是整数,也可以是另一个逆波兰表达式. 说明: 整数除法只保留整数部分. 给定逆波兰表达式总是有效的.换句话说 ...

  4. appium元素识别方式实战

    github代码::  https://github.com/w550856163/App_Demo.git  tag: V1.1 Appium Inspector定位工具界面介绍:  Selecte ...

  5. (二)数据源处理1-configparser读取.ini配置文件

    import osimport configparsercurrent_path =os.path.dirname(__file__)#获取config当前文件路径config_file_path = ...

  6. MySQL sql命令行操作数据库

    数据库命令行操作 命令行操作数据库, [if exists] 可加可不加, 命令行操作一定要加英文分号 ; 结尾 创建数据库 : create database [if not exists] 数据库 ...

  7. 【Redis】Redis基础 - Redis安装启动测试

    Redis基本 - 安装 文章目录 Redis基本 - 安装 Linux下安装Redis Docker 方式 Github 源码编译方式 直接安装方式 Windows下Redis安装 记录 - Red ...

  8. LeetCode501.二叉搜索树中的众数

    题目,本题未做出,还有很多要学习 class Solution { public: vector<int>ans; int base,count,maxCount; void update ...

  9. Golang应用性能问题排查分析

    背景 公司有一个使用golang开发的采集模块,负责调用多个外部系统采集数据:最近做了一次架构上的调整,将采集模块分成api.job两个子模块,并部署到容器中,拆分前部署在虚机上. 现象 部分采集任务 ...

  10. GitLab-CI/CD入门实操

    以Spring boot项目为例.传统方式是本地生成jar包,FTP上传服务器,重启服务:如果是内网测试服,也可以在服务器上安装git,在服务器上编译打包.但这都需要人为干预,于是CI/CD就出现了. ...