首页 > 其他分享 >AtCoder Beginner Contest 280 (A-D)

AtCoder Beginner Contest 280 (A-D)

时间:2022-12-18 13:00:11浏览次数:49  
标签:AtCoder include Beginner int ll mid ++ 280 质因数

本人第一次写博客,若有不足还望指出( •̀ ω •́ )✧

A

题意:输入一个H行W列的字符矩阵,统计'#'的个数。

解法/思路:挺简单的,直接贴代码吧。

代码:

#include <iostream>
#include <string>
using namespace std;
int main() {
	int n, m, ans = 0;
	cin >> n >> m;
	for (int i = 0; i < n; ++i) {
		string temp;
		cin >> temp;
		for (int j = 0; j < m; ++j) {
			if (temp[j] == '#') {
				++ans;
			}
		}
	}
	cout << ans;
	return 0;
}

 

B

题意:输入n个整数A1, A2 ... An,输出n个整数B1, B2 ... Bn,使得对于任意Ai,Ai = B1 + B2 + ... + Bi

解法/思路:令A0 = 0,显然Bi = Ai - Ai-1

代码:

#include <iostream>
using namespace std;
int a[11];
int main() {
	int n;
	cin >> n;
	for (int i = 1; i <= n; ++i) {
		cin >> a[i];
	}
	for (int i = 1; i <= n; ++i) {
		cout << a[i] - a[i - 1] << ' ';
	}
	return 0;
}

 

C

题意:字符串t是由字符串s插入一个小写字母得到的,问这个字母是t的第几个字符,若有多种可能,输出任意一种

解法/思路:逐个字符对比,找到第一个不同的即可。

代码:

#include <iostream>
#include <string>
using namespace std;
string s, t;
int main() {
	cin >> s >> t;
	int len = t.length();
	for (int i = 0; i < len; ++i) {
		if (s[i] != t[i]) {
			cout << i + 1;
			return 0;
		}
	}
}

 

D

题意:输入整数k,找到最小的n使得n!是k的倍数。

解法/思路:显然需要对k进行分解质因数。虽然k的范围是[1, 1e12],但实际上,大于√k的质因数至多只有一个。故只要在[1, 1e6]内查找k的质因数,再判断k分解到最后是否大于1即可。需要注意的是本题的答案不一定等于最大质因数,要考虑k的质因数分解的次数,例如,若k = 1120 = 25∗51∗71,n = 8。确定x!包含k分解结果的方法:质因数p在x!中出现的次数等于[x/p1] + [x/p2] + ... + [x/pm] (pm <= x)。拿9!举例,2的次数为[9/2] + [9/4] + [9/8] = 7。最后在[1, k]内找出n。

代码:

#include <iostream>
using namespace std;
typedef long long ll;
ll p[1000005];							// 记录k的质因数
ll cnt[1000005];						// 记录每个质因数的次数
ll num;									// 共有多少个质因数
bool check(ll mid);
int main() {
	ll k, k2, i;
	cin >> k;
	k2 = k;
	if (k % 2 == 0) {
		++num;
		p[1] = 2;
		while (k % 2 == 0) {
			k /= 2;
			++cnt[1];
		}
	}
	for (i = 3; i <= 1000000; i += 2) {
		if (k % i == 0) {
			p[++num] = i;
			while (k % i == 0) {
				k /= i;
				++cnt[num];
			}
		}
	}
	if (k > 1) {						// k > 1,此时的k一定是原来的k的大于1e6的质因数
		p[++num] = k;
		cnt[num] = 1;
	}
	// 数组p和cnt处理完毕
	ll l = 1, r = k2, mid;				// 用二分的思想,在[1, k]内寻找答案
	while (l < r) {
		mid = (l + r) >> 1;
		if (check(mid)) {				// 如果mid符合条件,在[l, mid]继续寻找
			r = mid;
		} else {						// 如果不符合,在[mid+1, r]继续寻找
			l = mid + 1;
		}
	}
	cout << l;
	return 0;
}
bool check(ll mid) {
	ll i, j, tot;						// 用tot记录质因数p[i]在mid!中的次数
	for (i = 1; i <= num; ++i) {
		tot = 0;
		for (j = p[i]; j <= mid; j *= p[i]) {
			tot += mid / j;
		}
		if (tot < cnt[i]) {
			return false;
		}
	}
	return true;
}

 

标签:AtCoder,include,Beginner,int,ll,mid,++,280,质因数
From: https://www.cnblogs.com/xbai2/p/16988849.html

相关文章

  • HHKB Programming Contest 2022 Winter(AtCoder Beginner Contest 282)
    前言好久没有打AtCoder了。有点手生。只拿到了\(\operatorname{rk}1510\),应该上不了多少分。只切了\(\texttt{A,B,C,D}\)四题。A-GeneralizedABC简要题意给出......
  • AcWing 2280. 最优标号
    AcWing2280.最优标号很神奇的建图,但是确实很有道理//多个进行匹配的问题#include<bits/stdc++.h>usingnamespacestd;usingll=longlong;constintN=1005,M=1e......
  • AtCoder Regular Contest 143 E Reversi
    AtCoder传送门洛谷传送门翻转一个点会把它相邻的点全部翻转,因此先从叶子开始自下而上考虑。不难发现,如果这个叶子是白色,那么它一定比它的父亲先翻转(否则它就翻不了了);而......
  • AtCoder Regular Contest 150 F Constant Sum Subsequence
    AtCoder传送门洛谷传送门定义\(\mathrm{nxt}(i,x)\)为最小的\(j\)满足\(a_j=x\)且\(j>i\),\(\mathrm{pre}(i,x)\)为最大的\(j\)满足\(a_j=x\)且\(j<......
  • atcoder beginner 281 DEFG 题解
    比赛链接:https://atcoder.jp/contests/abc281题解:D\(dp[i][j][k]\)表示考虑到第i个数,集合加入了\(k\)个数,余数为\(j\)的答案转移即可//bySkyRainWind#inclu......
  • AtCoder Beginner Contest 281
    A-CountDown(abc281a)题目大意给定\(n\),输出\(n\)到\(1\)。解题思路直接输出即可。神奇的代码#include<bits/stdc++.h>usingnamespacestd;usingLL=l......
  • atcoder beginner contest 144 Gluttony(二分答案)
    题目大意:有an,bn,我们找到an和bn每个元素的一种一一对应关系。使得min(max(ai*bi))。已知我们可以进行操作让an中的任一个元素减少1。操作数最大为k,问我们怎么操作,可以min(......
  • atcoder ABC 281(A-C)
    A要求你从N开始,一直打印到0。NN-1......3210简单#include<iostream>usingnamespacestd;intn;intmain(){ cin>>n; for(inti=n;i>=0;i--)cout<<i<<en......
  • AtCoder 问题乱做集1
    AGC014D BlackandWhiteTree*2266题目大意:两个人在$n$个节点的树上交替染色,先手染白色,后手染黑色。若染完之后有白点不与黑点相邻则先手胜,反之后手胜。求这棵树......
  • AtCoder Beginner Contest 242 F Black and White Rooks
    洛谷传送门AtCoder传送门不错的组合计数题。因为黑车和白车不能在同一行或者同一列,所以可以考虑枚举黑车有\(i\)行\(k\)列的位置放,白车有\(j\)行\(l\)列的位置......