传送门
A - September
分析
- 这一题是个模拟题,对当前第 i i i 个字符串的长度与 i i i 进行比较,相等时答案 + 1 +1 +1
#include<bits/stdc++.h>
using std::cin;
using std::cout;
using i32 = int;
using u32 = unsigned int;
using i64 = long long;
using u64 = unsigned long long;
using pii = std::pair<int, int>;
#define TESTS int _; std::cin >> _; while(_--)
#define all(a) a.begin(), a.end()
#define all1(a) a.begin() + 1, a.end()
#define pb push_back
#define fi first
#define se second
#define SUM(v) std::accumulate(all(v), 0LL)
#define SUM1(v) std::accumulate(all1(v), 0LL)
#define MIN(v) *std::min_element(all(v))
#define MIN1(v) *std::min_element(all1(v))
#define MAX(v) *std::max_element(all(v))
#define MAX1(v) *std::max_element(all1(v))
#define UNIQUE(v) std::sort(all(v)), v.erase(std::unique(all(v), v.end()))
#define UNIQUE1(v) std::sort(all1(v)), v.erase(std::unique(all1(v), v.end()))
constexpr i64 inf = 1E18, Md3 = 998244353, Md7 = 1e9 + 7;
constexpr double eps = 1E-9;
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
int ans = 0;
for(int i = 0; i < 12; i++) {
std::string s;
std::cin >> s;
if(s.size() == i + 1) {
ans++;
}
}
cout << ans;
return 0;
}
B - 1D Keyboard
分析
- 这一题由于 A B C D E F G … ABCDEFG\dots ABCDEFG…的顺序是固定的,所以依次记录 A B C D E F G … ABCDEFG\dots ABCDEFG…的位置,直接进行取绝对值即可
#include<bits/stdc++.h>
using std::cin;
using std::cout;
using i32 = int;
using u32 = unsigned int;
using i64 = long long;
using u64 = unsigned long long;
using pii = std::pair<int, int>;
#define TESTS int _; std::cin >> _; while(_--)
#define all(a) a.begin(), a.end()
#define all1(a) a.begin() + 1, a.end()
#define pb push_back
#define fi first
#define se second
#define SUM(v) std::accumulate(all(v), 0LL)
#define SUM1(v) std::accumulate(all1(v), 0LL)
#define MIN(v) *std::min_element(all(v))
#define MIN1(v) *std::min_element(all1(v))
#define MAX(v) *std::max_element(all(v))
#define MAX1(v) *std::max_element(all1(v))
#define UNIQUE(v) std::sort(all(v)), v.erase(std::unique(all(v), v.end()))
#define UNIQUE1(v) std::sort(all1(v)), v.erase(std::unique(all1(v), v.end()))
constexpr i64 inf = 1E18, Md3 = 998244353, Md7 = 1e9 + 7;
constexpr double eps = 1E-9;
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
std::map<char, int> mp;
std::string s;
std::cin >> s;
for(int i = 0; i < s.size(); i++) {
mp[s[i]] = i;
}
int ans = 0;
for(char i = 'B'; i <= 'Z'; i++) {
ans += abs(mp[char(i - 1)] - mp[i]);
}
cout << ans;
return 0;
}
C - Max Ai+Bj
分析
- 这题纸老虎,虽然在 C C C,其实和 A A A题差不多,只需要让 A A A 和 B B B数组中的最大值相加即可
#include<bits/stdc++.h>
using std::cin;
using std::cout;
using i32 = int;
using u32 = unsigned int;
using i64 = long long;
using u64 = unsigned long long;
using pii = std::pair<int, int>;
#define TESTS int _; std::cin >> _; while(_--)
#define all(a) a.begin(), a.end()
#define all1(a) a.begin() + 1, a.end()
#define pb push_back
#define fi first
#define se second
#define SUM(v) std::accumulate(all(v), 0LL)
#define SUM1(v) std::accumulate(all1(v), 0LL)
#define MIN(v) *std::min_element(all(v))
#define MIN1(v) *std::min_element(all1(v))
#define MAX(v) *std::max_element(all(v))
#define MAX1(v) *std::max_element(all1(v))
#define UNIQUE(v) std::sort(all(v)), v.erase(std::unique(all(v), v.end()))
#define UNIQUE1(v) std::sort(all1(v)), v.erase(std::unique(all1(v), v.end()))
constexpr i64 inf = 1E18, Md3 = 998244353, Md7 = 1e9 + 7;
constexpr double eps = 1E-9;
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
int n;
cin >> n;
std::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];
}
cout << MAX(a) + MAX(b);
return 0;
}
D - Hidden Weights
分析
- 这题由于 v − u = w v - u = w v−u=w,那么等式 u − v = − w u - v = -w u−v=−w,所以可以直接建双边,然后直接对 1 1 1进行dfs即可
#include<bits/stdc++.h>
using std::cin;
using std::cout;
using i32 = int;
using u32 = unsigned int;
using i64 = long long;
using u64 = unsigned long long;
using pii = std::pair<int, int>;
#define TESTS int _; std::cin >> _; while(_--)
#define all(a) a.begin(), a.end()
#define all1(a) a.begin() + 1, a.end()
#define pb push_back
#define fi first
#define se second
#define SUM(v) std::accumulate(all(v), 0LL)
#define SUM1(v) std::accumulate(all1(v), 0LL)
#define MIN(v) *std::min_element(all(v))
#define MIN1(v) *std::min_element(all1(v))
#define MAX(v) *std::max_element(all(v))
#define MAX1(v) *std::max_element(all1(v))
#define UNIQUE(v) std::sort(all(v)), v.erase(std::unique(all(v), v.end()))
#define UNIQUE1(v) std::sort(all1(v)), v.erase(std::unique(all1(v), v.end()))
constexpr i64 inf = 1E18, Md3 = 998244353, Md7 = 1e9 + 7;
constexpr double eps = 1E-9;
int main() {
std::ios::sync_with_stdio(false);
std::cin.tie(0);
int N, M;
cin >> N >> M;
std::vector<std::vector<pii>> adj(N);
std::vector<i64> ans(N);
for(int i = 0; i < M; i++) {
int u, v, w;
cin >> u >> v >> w;
u--;
v--;
adj[u].push_back({v, w});
adj[v].push_back({u, -w});
}
std::vector<bool> vis(N);
auto dfs = [&](auto self, int u, int fa) -> void {
vis[u] = true;
for(auto [v, w] : adj[u]) {
if(v == fa || vis[v]) {
continue;
}
ans[v] = ans[u] + w;
self(self, v, u);
}
};
for(int i = 0; i < N; i++) {
if(!vis[i]) {
dfs(dfs, i, -1);
}
}
for(int i = 0; i < N; i++) {
cout << ans[i] << " \n"[i == N - 1];
}
return 0;
}