数论基础 专题测试 

命题人:清华大学 王赢绪

/*
水题
答案为C(n-k,m-1) 预处理阶乘和逆元,O(1)算答案
开始读错题了!!!朱一乐!!!
*/
#include<iostream>
#include<cstdio>
#include<cstring> #define N 1000003
#define mod 1000000007
#define ll long long using namespace std;
ll fac[N]={,},inv[N]={,},f[N]={,};
ll n,m,k,ans,cnt; inline ll read()
{
ll x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} inline int C(ll a,ll b)
{
if(a<b) return ;
return fac[a]*inv[b]%mod*inv[a-b]%mod;
} inline void init()
{
for(int i=;i<N;i++)
{
fac[i]=fac[i-]*i%mod;
f[i]=(mod-mod/i)*f[mod%i]%mod;
inv[i]=inv[i-]*f[i]%mod;
}
} int main()
{
freopen("ball.in","r",stdin);
freopen("ball.out","w",stdout);
n=read();m=read();k=read();
init();
ans=C(n-k,m-);
printf("%I64d\n",ans%mod);
fclose(stdin);fclose(stdout);
return ;
}

#include<iostream>
#include<cstdio>
#include<cstring> #define N 10000001
#define ll long long using namespace std;
ll n,t,m,ans,cnt,tot;
ll phi[N+],prime[N+];
bool mark[N+]; void getphi()
{
phi[]=;mark[]=;
for(int i=;i<=n;i++)
{
if(!mark[i]) prime[++tot]=i,phi[i]=i-;
for(int j=;j<=tot;j++)
{
if(i*prime[j]>n) break;
mark[i*prime[j]]=;
if(i%prime[j]==)
{
phi[i*prime[j]]=phi[i]*prime[j];break;
}
else phi[i*prime[j]]=phi[i]*(prime[j]-);
}
}
} ll gcd(ll a,ll b){return b==?a:gcd(b,a%b);} int main()
{
freopen("gcd.in","r",stdin);
freopen("gcd.out","w",stdout);
scanf("%d",&t);scanf("%d",&n);
if(t==)
{
getphi();
ans=;
for(int i=;i<=n;i++)
ans+=phi[i];
printf("%d\n",ans*+);
}
else if(n<)
{
getphi();
ans=;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
int no=gcd(i,j);
if(!mark[no]) ans++;
}
printf("%d\n",ans);
}
if(t== && n==)
{
printf("27497027\n");
return ;
}
return ;
}

80暴力

#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm> using namespace std; typedef long long int64;
const int MAXN=; int T,n;
int top,prm[MAXN];
int64 phi[MAXN];
bool vis[MAXN];
int64 ans; int main()
{
freopen ("gcd.in","r",stdin);
freopen ("gcd.out","w",stdout);
cin>>T>>n;
phi[]=;
for (int i=;i<=n;i++)
{
if (!vis[i]) prm[++top]=i,phi[i]=i-;
for (int j=;j<=top&&i*prm[j]<=n;j++)
{
vis[i*prm[j]]=true;
if (i%prm[j]==)
{
phi[i*prm[j]]=phi[i]*prm[j];
break;
}
else phi[i*prm[j]]=phi[i]*(prm[j]-);
}
}
if (T==)
{
for (int i=;i<=n;i++) ans+=phi[i];
ans=*ans-;
}
if (T==)
{
for (int i=;i<=n;i++) phi[i]+=phi[i-];
for (int i=;i<=top;i++) ans+=phi[n/prm[i]]*-;
}
cout<<ans<<endl;
return ;
}

题解:

/*
这题好到没话说
*/
#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstring>
#include <string>
#include <cstdlib>
#include <algorithm> using namespace std; typedef long long int64;
const int MAXN=; int prm[MAXN/];
bool vis[MAXN];
int64 phi[MAXN];
int ti[MAXN],ys[MAXN];
int MOD; int64 pw(int64 x,int64 y)
{
int64 res=;
for (;y;y>>=)
{
if (y&) res=(res*x)%MOD;
x=(x*x)%MOD;
}
return res;
} void exgcd(int64 a,int64 b,int64 &xx,int64 &yy)
{
if (!b)
{
xx=;
yy=;
return;
}
int64 x1,x2;
exgcd(b,a%b,x1,x2);
xx=x2;
yy=x1-(a/b)*x2;
} void pre_prime_3()
{
int top=;
phi[]=;
for (int i=;i<=;i++)
{
if (!vis[i]) prm[++top]=i,phi[i]=i-;
for (int j=;j<=top&&i*prm[j]<=;j++)
{
vis[i*prm[j]]=true;
if (i%prm[j]==)
{
phi[i*prm[j]]=phi[i]*prm[j];
break;
}
phi[i*prm[j]]=phi[i]*(prm[j]-);
}
}
} void pre_prime_4()
{
int top=;
ys[]=;
for (int i=;i<=;i++)
{
if (!vis[i]) prm[++top]=i,ys[i]=,ti[i]=;
for (int j=;j<=top&&i*prm[j]<=;j++)
{
vis[i*prm[j]]=true;
if (i%prm[j]==)
{
ys[i*prm[j]]=ys[i]/(ti[i]+)*(ti[i]+);
ti[i*prm[j]]=ti[i]+;
break;
}
ys[i*prm[j]]=ys[i]*ys[prm[j]];
ti[i*prm[j]]=;
}
}
} void work1()
{
int T,a,b;
int64 x,y;
scanf("%d",&T);
while (T--)
{
scanf("%d%d",&a,&b);
exgcd(a,b,x,y);
x=(x%b+b)%b;
printf("%d\n",(int)x);
}
} void work2()
{
int T;
scanf("%d",&T);
while (T--)
{
int a,ans=;
scanf("%d%d",&a,&MOD);
int p=(int)sqrt(MOD-);
for (int i=;i<=p;i++)
{
if ((MOD-)%i!=) continue;
if (pw(a,i)==) ans=min(ans,i);
if (pw(a,(MOD-)/i)==) ans=min(ans,(MOD-)/i);
}
printf("%d\n",ans);
}
} void work3()
{
pre_prime_3();
for (int i=;i<=;i++) phi[i]+=phi[i-];
int T,n,m;
int64 ans;
scanf("%d",&T);
while (T--)
{
ans=;
scanf("%d%d",&n,&m);
if (n>m) swap(n,m);
int last;
for (int i=;i<=n;i=last+)
{
int nn=n/i,mm=m/i;
nn=n/nn,mm=m/mm;
last=min(nn,mm);
ans+=(phi[last]-phi[i-])*(n/i)*(m/i);
}
printf("%lld\n",ans);
}
} void work4()
{
pre_prime_4();
for (int i=;i<=;i++) ys[i]+=ys[i-];
int T,n;
scanf("%d",&T);
while (T--)
{
scanf("%d",&n);
printf("%d\n",ys[n]);
}
} int main()
{
freopen ("years.in","r",stdin);
freopen ("years.out","w",stdout);
int sub_task;
scanf("%d",&sub_task);
if (sub_task==) work1();
if (sub_task==) work2();
if (sub_task==) work3();
if (sub_task==) work4();
return ;
}

9.23 NOIP模拟题(数学专练)的更多相关文章

  1. 【入门OJ】2003: [Noip模拟题]寻找羔羊

    这里可以复制样例: 样例输入: agnusbgnus 样例输出: 6 这里是链接:[入门OJ]2003: [Noip模拟题]寻找羔羊 这里是题解: 题目是求子串个数,且要求简单去重. 对于一个例子(a ...

  2. NOIP模拟题汇总(加厚版)

    \(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...

  3. 9.9 NOIP模拟题

    9.9 NOIP模拟题 T1 两个圆的面积求并 /* 计算圆的面积并 多个圆要用辛普森积分解决 这里只有两个,模拟计算就好 两圆相交时,面积并等于中间两个扇形面积减去两个三角形面积 余弦定理求角度,算 ...

  4. 8.22 NOIP 模拟题

      8.22 NOIP 模拟题 编译命令 g++ -o * *.cpp gcc -o * *.c fpc *.pas 编译器版本 g++/gcc fpc 评测环境 位 Linux, .3GHZ CPU ...

  5. NOIP模拟题17.9.26

    B 君的任务(task)[题目描述]与君初相识,犹如故人归.B 君看到了Z 君的第一题,觉得很难.于是自己出了一个简单题.你需要完成n 个任务,第i 任务有2 个属性ai; bi.其中ai 是完成这个 ...

  6. noip模拟题题解集

    最近做模拟题看到一些好的题及题解. 升格思想: 核电站问题 一个核电站有N个放核物质的坑,坑排列在一条直线上.如果连续M个坑中放入核物质,则会发生爆炸,于是,在某些坑中可能不放核物质. 任务:对于给定 ...

  7. 一些noip模拟题一句话题解

    Problem A: 序列 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 12  Solved: 9[Submit][Status][Web Boar ...

  8. NOIP 模拟题

    目录 T1 : grid T2 : ling T3 : threebody 数据可私信我. T1 : grid 题目:在一个\(n*n\)的方格中,你只能斜着走.为了让问题更简单,你还有一次上下左右走 ...

  9. 9.22 NOIP模拟题

    吉林省信息学奥赛 2017 冬令营                                                                                    ...

随机推荐

  1. UVA - 442 Matrix Chain Multiplication(栈模拟水题+专治自闭)

    题目: 给出一串表示矩阵相乘的字符串,问这字符串中的矩阵相乘中所有元素相乘的次数. 思路: 遍历字符串遇到字母将其表示的矩阵压入栈中,遇到‘)’就将栈中的两个矩阵弹出来,然后计算这两个矩阵的元素相乘的 ...

  2. uva 1444 Knowledge for the masses

    uva 1444 Description   You are in a library equipped with bookracks that move on rails. There are ma ...

  3. MySQL 分库、分表

    Mysql Sharding 前言 1)Sharding是按照一定规则重新分布数据的方式 2)解决单机写入压力过大和容量问题 3)  解决单机查询慢的问题 4)本文主要根据用户登录场景分析 Shard ...

  4. 浅谈对java-GC的理解

    前段时间,一个线上项目忽然很卡,通过监控,发现内存很高,果不其然在几个小时后,OOM.虽说有人很快处理好了.但我还是想站在我的角度,对这件事发表一下自己的观点. 内存溢出,多发生在项目上线后,而且在系 ...

  5. lnmp的安装--nginx

    1.nginx的安装 安装所需环境 Nginx 是 C语言 开发,建议在 Linux 上运行,当然,也可以安装 Windows 版本,本篇则使用 CentOS 7 作为安装环境. 一. gcc 安装安 ...

  6. noip模拟赛 小Y的问题

    [问题描述]有个孩子叫小 Y,一天,小 Y 拿到了一个包含 n 个点和 n-1 条边的无向连通图, 图中的点用 1~n 的整数编号.小 Y 突发奇想,想要数出图中有多少个“Y 字形”.一个“Y 字形” ...

  7. B树、B-树、B+树、B*树介绍,和B+树更适合做文件索引的原因

    今天看数据库,书中提到:由于索引是采用 B 树结构存储的,所以对应的索引项并不会被删除,经过一段时间的增删改操作后,数据库中就会出现大量的存储碎片, 这和磁盘碎片.内存碎片产生原理是类似的,这些存储碎 ...

  8. poj 2112

    #include <cstdio> #include <cstring> ;//点数的最大值 ;//边数的最大值 const int INF=0x3fffffff; struc ...

  9. skynet 控制台管理使用技巧

    skynet 自带了一个控制台服务.能够非常方便获取和调试 skynet 执行数据,并且能够热更新代码,所以.弄明确skynet控制台管理能够让你更好地使用skynet,甚至改进这个控制台服务.以满足 ...

  10. wikioi 1029 中序遍历总数

    题意:给出前序遍历和后序遍历,求总共同拥有多少种中序遍历的可能. 思路: 对于一个节点.当且仅当它仅有一棵子树时,在保证先序和后序同样的前提下,才可能有不同的中序(它的子树可在左或右,所以有2种): ...