CF-1110
A. Parity
- 快速幂的思想,考虑最后一位即可
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll b,k;
ll a[100010];
int main(){
scanf("%lld%lld",&b,&k);
for(int i=0;i<k;i++)
scanf("%lld",&a[i]);
ll ans = 0;
ll base = 1;
for(int i=0;i<k;i++){
ans = (ans+a[k-i-1]*base)%10;
base = base*b%10;
}
if(ans%2)puts("odd");
else puts("even");
return 0;
}
可以再多想一想。
\[n = a_1\cdot b^{k-1} + a_2\cdot b^{k-2} + \cdots + a_{k-1} \cdot b + a_k\]
- b为偶数时,n的奇偶性只与\(a_k\) 有关
- b为奇数时,\(b^k\) 为奇数,所有n的奇偶性只与 a 序列中奇数个数有关。
#include<bits/stdc++.h>
using namespace std;
int b,k,i,x,y;
int main(){
for(cin>>b>>k;i<k;i++)
cin>>x,y+=x%2;
cout<<((b%2?y%2:x%2)?"odd":"even");
}
B. Tape
n == k 时直接输出 n 就好
n <= k 时,一些点要合并,由于合并产生的操作可能会使一段上面有多个点,所以我们要先把 k 个点都用长度为 1 的去填好。之后合并的时候只需要考虑点与点之间的距离即可(YY一下,你就知道)
- 当 k 等于 n,则直接输出 n
- 当 k 小于 n,则先把k段用长度为1补齐,再加上 (n-k) 段比较小的距离。
#include <bits/stdc++.h>
using namespace std;
int n,m,k;
int a[100010];
int main(){
scanf("%d%d%d",&n,&m,&k);
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
for(int i=n-1;i>0;i--)
a[i] = a[i]-a[i-1];
sort(a+1,a+n);
int ans = k;
for(int i=1;i<=(n-k);i++)
ans += a[i];
cout<<ans<<endl;
return 0;
}
C. Meaningless Operations
根据 Note 可以得知只要凑出一个 0 ,就可能得到最大的gcd。
-
当 \(a\neq (2^x -1)\) , 则一定可以找到一个 b 使得
- $ a \oplus b = 2^x -1$ , \(a \& b = 0\)
-
当 \(a = (2^x - 1)\) ,则可以发现
\[gcd( a\oplus b, a\&b) = gcd(2^x-1-b,b) = gcd(2^x-1,b)\]
- 因为 \(gcd(x,x+y) = gcd(x,y)\)
- 所以只需要找到 a 的最大因数(非a) 即可。
复杂度\(O(q\sqrt m)\) 。但是可以打表做(也可以直接暴力求)
#include <bits/stdc++.h>
using namespace std;
int po[30];
int res[30] = {0,1,1,1,5,1,21,1,85,73,341,89,1365,1,5461,4681,21845,1,87381,1,349525,299593,1398101,178481,5592405,1082401,22369621};
void init(){
po[0] = 1;
for(int i=1;i<30;i++)
po[i] = po[i-1]*2;
}
bool check(int x){
for(int i=1;i<30;i++)
if(x==po[i]-1)
return true;
return false;
}
int calc(int x){
int num =0;
while(x)
{
x/=2;
num++;
}
return num;
}
int main(){
init();
int q;
cin>>q;
while(q--){
int n;
cin>>n;
if(check(n)){
int num = calc(n);
cout<<res[num]<<endl;
}
else{
for(int i=1;i<30;i++){
if(n>=po[i]&&n<po[i+1]){
cout<<po[i+1]-1<<endl;
break;
}
}
}
}
}