AtCoder Beginner Contest 373(A - D)

传送门

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 vu=w,那么等式 u − v = − w u - v = -w uv=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;
}	
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值