Luogu P1450 [HAOI2008]硬币购物 解题报告
共有
4 种硬币。面值分别为c_1,c_2,c_3,c_4 。某人去商店买东西,去了
n 次,对于每次购买,他带了d_i 枚i 种硬币,想购买s 的价值的东西。请问每次有多少种付款方法。
共有
4 种硬币。面值分别为c_1,c_2,c_3,c_4 。某人去商店买东西,去了
n 次,对于每次购买,他带了d_i 枚i 种硬币,想购买s 的价值的东西。请问每次有多少种付款方法。
有一个由按钮组成的矩阵,其中每行有6个按钮,共5行。每个按钮的位置上有一盏灯。当按下一个按钮后,该按钮以及周围位置(上边、下边、左边、右边)的灯都会改变一次。
即,如果灯原来是点亮的,就会被熄灭;如果灯原来是熄灭的,则会被点亮。在矩阵角上的按钮改变3盏灯的状态;在矩阵边上的按钮改变4盏灯的状态;其他的按钮改变5盏灯的状态。
请你写一个程序,确定需要按下哪些按钮,恰好使得所有的灯都熄灭。
根据上面的规则,我们知道
第2次按下同一个按钮时,将抵消第1次按下时所产生的结果。因此,每个按钮最多只需要按下一次
各个按钮被按下的顺序对最终的结果没有影响
- 对第1行中每盏点亮的灯,按下第2行对应的按钮,就可以熄灭第1行的全部灯。
如此重复下去,可以熄灭第1、2、3、4行的全部灯。同样,按下第1、2、3、4、5列的按钮,可以熄灭前5列的灯。
求
\sum\limits_{i=1}^n \gcd(i, n)
n \leq 2 ^ {32}
数学题。(第一次推出式子来真的好开心hhhh)
首先看到 gcd ,第一反应应该是从
那么我们把
我们要求的东西其实就是
化简一波式子:
然后直接算就行了。
时间复杂度
ll n,ans;
ll phi(int x) {
if (x == 1) return 1;
ll ans = x;
for (int i = 2;i *i <= x;++i) {
if (x % i == 0) {
while (x % i == 0) {x /= i;}
ans = (ans * (i-1) / i);
}
}
if (x > 1) ans = (ans * (x-1) / x);
return ans;
}
signed main() {
read(n);
for (int i = 1;i * i <= n;++i) {
if (n % i == 0) {
ans += i*phi(n/i);
if (i * i != n) ans += n/i * phi(i);
}
}
printf("%lld",ans);
return 0;
}