A. A
发现不断加a,乘b。
枚举将s乘k次b,则有
$t=s*b^k+\sum \limits_{i=0}^{k-1}used[i]*a*b^i$
答案即是使得$\sum \limits_{i=0}^{k-1}used[i]$最小的方案。
将s,t表示为b进制会比较好算。
当a=1时,贪心地选择就可以了。
然后a!=1就不会打了。
其实将差值除一个a,问题就转化为了a=1的问题。
B. B
通过打表发现一些性质:
若$gcd(i,p)=gcd(j,p)$,则$ans(i)=ans(j)$。
在数据范围$p<=1e9$内,p最多只有不到两千个因子。
所以将p个数分为因子个数个组,
每个组中的每个元素与p的gcd相同,设为k,
则取k为这个组的代表元素,这个组的元素个数为$phi(p/k)$。
所以直接将最暴力$O(n*p^2)$的dp改为$O(n*d(p)^2)$,$d(x)$为x的约数个数。
C. C
最近做了很多关于区间覆盖的题,然而都没有做出来。
大致思路都是将这些区间先按左端点排序。
同理,本题排序后贪心。
因为本题中有一个很关键的性质:每个区间的权值都为1。
所以从左到右考虑每个点,取得跨过这个点的右端点最靠右的区间就可以了。
然而有一个特殊的区间,处理方式是枚举选特殊区间多少次。
这个复杂度是有问题的,所以考虑三分选的次数,就可以了。