2017 icpc 西安网络赛
F. Trig Function
样例输入
2 0
2 1
2 2
样例输出
998244352
0
2
找啊找啊找数列和论文。cosnx可以用切比雪夫多项式弄成(cosx)的多项式,然后去找到了相关的公式:
然后写个快速幂预处理啥的,很快就解决了~
#include<bits/stdc++.h>
#define clr(x) memset(x,0,sizeof(x))
#define clr_1(x) memset(x,-1,sizeof(x))
#define LL long long
#define mod 998244353
using namespace std;
LL jc[],djc[];
LL n,m,k,ans;
LL quick_pow(LL x,LL n)
{
LL res=;
x=(x%mod+mod)%mod;
while(n)
{
if(n&)
res=res*x%mod;
x=x*x%mod;
n>>=;
}
return res;
} void init()
{
jc[]=jc[]=;
for(int i=;i<=;i++)
jc[i]=(jc[i-]*i)%mod;
djc[]=quick_pow(jc[],mod-);
for(int i=;i>=;i--)
djc[i]=djc[i+]*(i+)%mod;
djc[]=;
return ;
}
int main()
{
init();
while(scanf("%lld%lld",&n,&m)!=EOF)
{
if(m>n || m< || (n-m)%!=)
{
printf("0\n");
continue;
}
ans=(n-m)/%==?-:;
ans=(ans*djc[m]*n%mod+mod)%mod;
if(n-m<=n+m-)
for(LL i=n-m+;i<=n+m-;i+=)
ans=ans*(i%mod)%mod;
else
for(LL i=n-m;i>n+m-;i-=)
ans=ans*quick_pow(i,mod-)%mod;
printf("%lld\n",ans);
}
return ;
}
E。 Maximum Flow
样例输入
2
样例输出
1
这题可以用最大流最小割推推,但我~找规律的2333。
首先是2^k的n(默认n--了),那么所有的从0出来的流都能到达终点,也就是流量为(n+1)*n/2。然后写个最大流打个表,然后将i和i-1作差。可以发现在2^k~2^(k+1)的数中,差为2(2^0+1)每隔2个出现,差为5(2^2+1)每隔4个出现,17(2^4+1)每隔8个出现。。。依此类推。然后你懂得~。
#include<bits/stdc++.h>
#define clr(x) memset(x,0,sizeof(x))
#define LL long long
#define mod 1000000007
using namespace std;
LL quick_pow(LL x, LL n) {
LL res = ;
x=(x%mod+mod)%mod;
while(n) {
if(n&)
res=res*x% mod;
n >>=;
x =x*x% mod;
}
return res;
}
int main()
{
LL n,m,q,l,ans,k,kk;
int t;
while(scanf("%lld",&n)!=EOF)
{
t=;
n--;
m=n;
while(m)
{
t++;
m>>=;
}
q=;
m=(q<<(t-));
ans=(m%mod)*((+m)%mod)%mod;
ans=ans*quick_pow(,mod-)%mod;
n-=m;
kk=;
k=;
while(k<=n+kk)
{
ans=(ans%mod+(((n+kk)/k)%mod)*((kk%mod)*(kk%mod)%mod+)%mod)%mod;
if(k==LLONG_MAX)
break;
kk=k;
k<<=;
}
printf("%lld\n",ans);
}
return ;
}
C.Sum
样例输入
1
1
样例输出
89999999999999999999999999
输入啥都输出233个9就行了。k个9无论乘多少数位和仍是k*9。
#include<bits/stdc++.h>
#define clr(x) memset(x,0,sizeof(x))
#define clr_1(x) memset(x,-1,sizeof(x))
#define LL long long
using namespace std;
int main()
{
LL n,m,k;
int T;
scanf("%d",&T);
while(T--)
{
scanf("%lld",&n);
for(int i=;i<=;i++)
printf("");
printf("\n");
}
return ;
}
B.Coin
样例输入
2
2 1 1
3 1 2
样例输出
500000004
555555560
23333,n重伯努利实验概率分布题。
设q=1-p,p为事件概率。
Y为出现偶数次的概率。
所以Y=(1+(q-p)^n)/2,求个逆元啥的,快速幂啥的就能做出来了。
#include<bits/stdc++.h>
#define LL long long
#define mod 1000000007
using namespace std;
LL quick_pow(LL x, LL n) {
LL res = ;
x=(x%mod+mod)%mod;
while(n) {
if(n&)
res=res*x% mod;
n >>=;
x =x*x% mod;
}
return res;
}
int main()
{
LL p, q;
LL n;
int t;
scanf("%d", &t);
while(t --) {
scanf("%lld%lld%lld",&p, &q, &n);
LL a=quick_pow(p,mod-);
a=(a**q)%mod;
a=(-a+mod)%mod;
a=quick_pow(a,n)%mod;
a=(a+)%mod;
LL b=quick_pow(,mod-)%mod;
a=(a*b)%mod;
printf("%lld\n", (a%mod+mod)%mod);
}
}
2017 icpc 西安网络赛的更多相关文章
- 2017年icpc西安网络赛 Maximum Flow (找规律+数位dp)
题目 https://nanti.jisuanke.com/t/17118 题意 有n个点0,1,2...n-1,对于一个点对(i,j)满足i<j,那么连一条边,边权为i xor j,求0到n- ...
- 2017 icpc 沈阳网络赛
cable cable cable Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 2017 ICPC西安区域赛 A - XOR (线段树并线性基)
链接:https://nanti.jisuanke.com/t/A1607 题面: Consider an array AA with n elements . Each of its eleme ...
- 2017 ACM-ICPC 西安网络赛 F.Trig Function Chebyshev多项式
自己太菜,数学基础太差,这场比赛做的很糟糕.本来想吐槽出题人怎么都出很数学的题,现在回过头来想还是因为自己太垃圾,竞赛就是要多了解点东西. 找$f(cos(x))=cos(nx)$中$x^m$的系数模 ...
- 2017 icpc 南宁网络赛
2000年台湾大专题...英语阅读输入输出专场..我只能说很强势.. M. Frequent Subsets Problem The frequent subset problem is define ...
- hdu5017:补题系列之西安网络赛1011
补题系列之西安网络赛1011 题目大意:给定一个椭球: 求它到原点的最短距离. 思路: 对于一个椭球的标准方程 x^2/a^2 + y^2/b^2 +z^2/c^2=1 来说,它到原点的最短距离即为m ...
- 2018 ICPC 沈阳网络赛
2018 ICPC 沈阳网络赛 Call of Accepted 题目描述:求一个算式的最大值与最小值. solution 按普通算式计算方法做,只不过要同时记住最大值和最小值而已. Convex H ...
- 2018 ICPC 徐州网络赛
2018 ICPC 徐州网络赛 A. Hard to prepare 题目描述:\(n\)个数围成一个环,每个数是\(0\)~\(2^k-1\),相邻两个数的同或值不为零,问方案数. solution ...
- hdu6212[区间dp] 2017青岛ACM-ICPC网络赛
原题: BZOJ1032 (原题数据有问题) /*hdu6212[区间dp] 2017青岛ACM-ICPC网络赛*/ #include <bits/stdc++.h> using name ...
随机推荐
- 探索ReactNative应用
本篇文章是我看AC2016腾讯前端技术交流大会后写的.写的不好,大家见谅啊. 一,什么是ReactNative? 简单来说就是可以用javascript来写APP了,而且性能还不错. 用JS写的话已经 ...
- yocto 离线编译
使用yocto编译一个软件包时,一般会先在本地寻找下载好的源码包,如果不存在则根据配置从网络下载. 添加本地源码包 为了支持离线编译,添加一个包的配置文件后,需要在本地也准备好源码包. 可以先打开网络 ...
- Linux 入门记录:十七、Linux 命令行文本/文件处理工具
一.文件浏览 cat 查看文件内容 more 以翻页形式查看文件内容(只能向下翻页) less 以翻页形式查看文件内容(可以上下翻页) head 查看文件的头几行(默认10行) tail 查看文件的尾 ...
- 浅析linux内核中timer定时器的生成和sofirq软中断调用流程【转】
转自:http://blog.chinaunix.net/uid-20564848-id-73480.html 浅析linux内核中timer定时器的生成和sofirq软中断调用流程 mod_time ...
- 【jzoj6.24模拟B】
这场真是无聊,搬远古原题…… xjb做了做,(居然没AK真是身败名裂) A.教主的花园 答案明显具有可二分性,二分答案判定下就行. #include<bits/stdc++.h> #def ...
- centos7.4通过yum安装mysql
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- IE8下面的line-height的bug
当line-height小于正常值时,超出的部分将被剪裁掉
- [PAT] 1147 Heaps(30 分)
1147 Heaps(30 分) In computer science, a heap is a specialized tree-based data structure that satisfi ...
- Python 什么是ORM?
关系映射 性能比源生sql效率略差一些 操作性更简单,快捷 Django的orm和sqlalchamy 区别 sqlalchamy没有django的功能全,不支持双下划线的连表跨表操作 sqlalch ...
- LeetCode解题报告—— Number of Islands & Bitwise AND of Numbers Range
1. Number of Islands Given a 2d grid map of '1's (land) and '0's (water), count the number of island ...