首页 > 其他分享 >6.12高一高考集训欢乐赛

6.12高一高考集训欢乐赛

时间:2024-06-12 20:33:38浏览次数:35  
标签:约数 cnt gcd cdot 6.12 高一 集训 read sum

前面是题解,后面是垃圾话

T1 Efim与奇怪的成绩

贪心的找第一个可以四舍五入的,然后往上进位。

T2 Beautiful IP Addresses

因为回文,所以 \(n\ge 7\) 太长了,不合法,并且只用找一半,爆搜 check 即可。

T3 装饰

结论题?发现两个上界:\(\frac{a+b+c}{3},a+b+c-\max(a,b,c)\),答案就是两者中较小的一个。
假设 \(a\) 最大,

  • 当 \(\frac{a+b+c}{3}\le b+c\),即 \(a\le 2b+2c\),假设我们先拿 \(3\) 个都有的,然后我们可以用较多的一个替换这些 \(3\) 个都有的中较少的一个,这样一直平衡,最后可以分成 \(\frac{a+b+c}{3}\) 组。

  • 当 \(\frac{a+b+c}{3}>b+c\) ,即 \(a>2b+2c\),此时全都拿两个 \(a\),一个 \(b\) 或 \(c\) 就行。

T4 最大子矩阵Largest Submatrix

枚举 \(a,b,c\),然后就是 玉蟾宫。考虑记一下每个位置最多能往上延伸多少行,然后就相当于在每一行中找面积最大,单调栈板子。

T5 P2051 [AHOI2009] 中国象棋

清新小 DP,观察到每行每列最多填两个,设 \(f_{i,j,k}\) 表示填到了第 \(i\) 行,有 \(j\) 列是空列,有 \(k\) 列是只有一个炮的列。

\[\begin{aligned} \begin{cases} f[i][j][k]=f[i][j][k]+f[i-1][j][k]; 这一行不填\\ f[i][j][k]=f[i][j][k]+f[i-1][j+1][k-1]*(j+1);这一行在空列中填一个,此时会增加一个只有一个炮的列\\ f[i][j][k]=f[i][j][k]+f[i-1][j][k+1]*(k+1);这一行在有一个炮的列中填一个\\ f[i][j][k]=f[i][j][k]+f[i-1][j+2][k-2]*(j+2)*(j+1)/2;这一行在空列中填两个\\ f[i][j][k]=f[i][j][k]+f[i-1][j+1][k]*(j+1)*k;这一行在空列和只有一个炮的列中各填一个\\ f[i][j][k]=f[i][j][k]+f[i-1][j][k+2]*(k+2)*(k+1)/2;这一行在只有一个炮的列中填两个; \end{cases} \end{aligned} \]

直接 DP 即可。

T6 [BZOJ2813 奇妙的Fibonacci]

设 \(f_i\) 表示斐波那契数第 \(i\) 项,有定理即 \(\gcd(f_i,f_j)=f_{\gcd(i,j)}\),如果 \(f_i\mid f_j\Leftrightarrow \gcd(f_i,f_j)=f_i\Leftrightarrow\gcd(i,j)=i\Leftrightarrow i\mid j\),从而有 \(f_i\mid f_j\Leftrightarrow i\mid j\),所以就是求 \(1\) 到 \(n\) 中每个数的约数个数和约数平方和。
该定理证明如下:
引理1:\(\gcd(f_n,f_{n+1})=1\)
证明:根据 \(\gcd(a,b)=\gcd(a,b-a)\),有 \(\gcd(f_n,f_{n+1})=\gcd(f_n,f_{n-1}+f_n)=\gcd(f_n,f_n-1)=\cdots=\gcd(f_1,f_2)=1\)。
引理2:\(f_m=f_{m-n-1}\cdot f_n+f_{m-n}\cdot f_{n+1}\)
证明:设 \(f_n=a,f_{n+1}=b\),有 \(f_{n+2}=a+b,f_{n+3}=a+2b,f_{n+4}=2a+3b,\cdots f_m=f_{m-n-1}\cdot a+f_{m-n}\cdot b=f_{m-n-1}\cdot f_n+f_{m-n}\cdot f_{n+1}\)。
根据上面两个引理,可以得出 \(\gcd(f_n,f_m)=\gcd(f_n,f_{m-n-1}\cdot f_n+f_{m-n}\cdot f_{n+1})=\gcd(f_n,f_{m-n}\cdot f_{n+1})\),根据引理2,有 \(\gcd(f_n,f_{m-n}\cdot f_{n+1})=\gcd(f_n,f_{m-n})\),以此类推,\(\gcd(f_n,f_{m-n})=\gcd(f_n,f_{m-n-n})=\cdots=\gcd(f_1,f_{\gcd(n,m)})=f_{\gcd(n,m)}\),根据更相减损法得证。
显然约数的个数 \(f(x)\) 满足互质积性,而约数平方和 \(sum(x)\) 也满足互质积性。这个比较显然,不证了。
此时 狄利克雷前缀和 可以解决这个问题,时间复杂度 \(\mathcal{O}(n\log\log n)\),不讲。
此时线性筛就可以解决这个问题。
设 \(cnt_i\) 表示 \(i\) 的最小质因数的次数,\(f_i\) 表示 \(i\) 的约数个数,\(s_i\) 表示 \(i\) 除去所有最小质因数后的数,\(sum_i\) 表示 \(i\) 的约数平方和。
设 \(x=i\cdot p\),当 \(p\nmid i\) 时,\(cnt_x=cnt_i+1,s_x=s_i,f_x=f_{s_i}\cdot f_p,sum_x=f_{s_i}\cdot f_p\)
当 \(p\mid i\) 时,\(cnt_x=cnt_i+1,s_x=s_i,f_x=f_{s_i}\cdot (cnt_x+1),sum_x=sum_i\cdot p^2\cdot sum_{s_i}\)
还有一个细节,就是 \(f_2=1\),可以被任何数整除,所以当询问为奇数时特判加上就好。

#include<bits/stdc++.h>
#define int long long
typedef long long ll;
typedef unsigned long long ull;
inline int read(){char ch=getchar();int x=0,f=1;for(;ch<'0'||ch>'9';ch=getchar())if(ch=='-')f=-1;for(;ch>='0'&&ch<='9';ch=getchar())x=(x<<3)+(x<<1)+(ch^48);return x*f;}
const int N=1e7+10,mod=1e9+7;
int f[N],sum[N],s[N],p[N],cnt[N],tot;
bool vis[N];
inline int mo(int x){return x<0?(x%mod+mod)%mod:(x>=mod)?x%mod:x;}
signed main(){
	freopen("fibo.in","r",stdin);freopen("fibo.out","w",stdout);
	std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);
	int q=read();
	int q1=read(),a=read(),b=read(),c=read();
	f[1]=1,sum[1]=1;
	for(int i=2;i<=c;++i){
		if(!vis[i])p[++tot]=i,sum[i]=mo(i*i+1),f[i]=2,s[i]=1,cnt[i]=1;
		for(int j=1;j<=tot&&p[j]*i<=c;++j){
			int zc=p[j]*i;
			vis[zc]=1;
			if(i%p[j]==0){
				s[zc]=s[i];
				cnt[zc]=cnt[i]+1;
				f[zc]=(cnt[zc]+1)*f[s[zc]];
				sum[zc]=mo(sum[i]*p[j]%mod*p[j]%mod+sum[s[i]]);
				break;
			}
			cnt[zc]=1;
			f[zc]=mo(f[p[j]]*f[i]);
			sum[zc]=mo(sum[p[j]]*sum[i]);
			s[zc]=i;
		}
	}
	int S=0,ans=0;
	for(int i=1;i<=q;++i){
		S=(S+f[q1]+(q1&1))%mod;
		ans=(ans+sum[q1]+4*(q1&1))%mod;
		q1=(q1*a+b)%c+1;
	}
	std::cout<<(ll)S<<'\n'<<(ll)ans<<'\n';
}
点击查看垃圾话
又到六月份了,都过去一年了。

标签:约数,cnt,gcd,cdot,6.12,高一,集训,read,sum
From: https://www.cnblogs.com/Ishar-zdl/p/18244500

相关文章

  • 高一高考集训欢乐赛
    注意细节点击查看代码#include<bits/stdc++.h>#definelllonglong#definemkmake_pair#definepbpush_back#definelid(rt<<1)#definerid(rt<<1|1)#definespeed()ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);usingnamespacestd;cons......
  • 2024/6/12高一高考集训欢乐赛题解
    目录赛时榜T1.Efim与奇怪的成绩T2.美丽的IP地址赛时榜你说得对,但是安禄山进长安——\(\huge{唐完了}\)。T1.Efim与奇怪的成绩贪心题+小模拟。先说结论:从小数点往后找到第一个可以四舍五入的位置,然后开始四舍五入。证明:首先,小数位数靠后的如果四舍五入,收益肯定是没前面的......
  • 高一高考集训欢乐赛
    大石碎胸口——万能青年旅店久违的头图渔王还想继续做渔王而海港已经不知去向此刻他醉倒在洗浴中心没有潮汐的梦胸口已暮色苍茫肥胖的城市递给他一个传统的方法来克制恐慌卖掉武器风暴喉咙换取饮食背叛能让你获得自由停电之后暂时摆脱了坚硬的时刻倒转......
  • 6.12(1)线性规划应用案例的求解
    (1)线性规划应用案例的求解1、基本要求通过一个农业生产计划优化安排的实例求解,培养学生解决实际线性规划问题的初步能力;熟悉线性规划的建模过程;掌握Matlab优化工具箱中线性规划函数的调用。2、主要内容某村计划在100公顷的土地上种植a、b、c三种农作物。可以提供的劳力、粪肥和......
  • 2024.6.12(个人总结)
    所学时间:2小时代码行数:110博客园数:1篇所学知识:  在第一周的课程计划中,我着重安排了学习安卓端的开发应用、掌握javaweb框架的应用、以及开始熟悉数据库的增删改查操作。下面是我在这些方面的具体进展:安卓端的开发应用,学习并掌握了安卓应用的基本结构,包括活动(Activity)、布......
  • 2024 广东省队集训
    5.21试机赛B.朴素计数,写个dp算贡献系数就好了。C.网路流。建边\((s,i_0,C),(i_1,t,C),(i_0,j_1,dis_{i,j})\),跑最大流即可。5.22A.首先分析一下贡献的形式。因为这玩意是凸的,所以我们可以钦定一个选点顺序,优先让第一个最大,其次让第二个最大,以此类推。很容易猜测选的点......
  • 大一下集训队选拔赛
    rank2还需努力7paoxiaomo不爱DP很简单的一道DP赛时看错数据范围导致陷入思考误区其实只用求每个前缀和对应的答案然后往后合并区间一但有区间和等于pre[i]那么将该区间加入并且计算贡献如果区间和大于pre[i]那么该答案不符合点击查看代码#include<bits/stdc++.h>#de......
  • 高考假+端午 集训
    6.5whk?水本来是今天开始集训的来着但是要去看牙,所以能多待一天......
  • 高考假+端午 集训
    6.5whk?水本来是今天开始集训的来着但是要去看牙,所以能多待一天......
  • 高考假集训总结(6.9)
    6.9今天依然是单调队列优化dp和斜率优化dp(只不过斜率优化的题还没开始做,具体原因下面讲)突然发现自己学得越多,忘得越多,都想不起来单调队列怎么用了,于是又花一上午跑回去看了单调队列的题并调了一上午的t1暴力做法,现在终于可以将两者融会贯通也就是成功实现了单调队列优化dp不......