Yali7月集训Contest2 T1 Cube 题解
题目链接:
连我们都只有纸质题目...话说雅礼集训都是这样的吗...
大意
0维基本图形是一个点
1维基本图形是一条线段
2维基本图形是一个正方形
3维基本图形是一个正方体
4维基本图形是...
求\(n\)维基础图形中有多少个\(m\)维基础图形\((n>=m)\)并对\(998244353\)取模
分析
手玩样例打表吼啊
当然还是要暗中观察一下啦
线段变成正方形,点数变为原来两边,边数除了变为原来两倍之外还要加上原来点数所对应连起来的边
正方形变正方体也类似
于是我就yy出一个递推式\(num[x][m]=num[x-1][m]*2+num[x-1][m-1]\)
\(num[x][m]\)表示\(x\)维基础图形中含有\(m\)维基础图形的数量
然后我们可以打一张表
然后就有dalao发现了规律(我比较傻考场上都手玩出每一项能整除2的幂都没发现规律)
\(num[n][m]/2^{n-m}=C^n_m\)
然后就ok了
注意
在订正这道题时发现几个值得注意的地方
线性求逆元时我原来的方法不行
原来我这么线性求逆元
inv[i]=(-(p/i)*inv[p%i]%p);
```
结果我发现数字一大就GG了
这是大佬的线性求逆元
```
inv[i]=(ll)(p-(p/i))*inv[p%i]%p;
```
这就很稳了
一个有趣的性质
逆元的阶乘是原来数字阶乘的逆元
很有趣,好象可证
代码:
include
include
include
include
include
include
include
define ri register int
define ll long long
using namespace std;
const int maxn=100005;
const int inf=0x7fffffff;
const int p=998244353;
template inline void read(T &x){
x=0;int ne=0;char c;
while(!isdigit(c=getchar()))ne=c'-';
x=c-48;
while(isdigit(c=getchar()))x=(x<<3)+(x<<1)+c-48;
x=ne?-x:x;
return ;
}
int inv[maxn],twopow[maxn],fac[maxn];
inline void pre(){
inv[0]=inv[1]=1,fac[1]=1,twopow[0]=1,twopow[1]=2;
for(ri i=2;i<=100002;i++){
fac[i]=(ll)fac[i-1]i%p;
inv[i]=(ll)(p-(p/i))inv[p%i]%p;
twopow[i]=(ll)(twopow[i-1]<<1)%p;
//cout<<fac[i]<<' '<<inv[i]<<' '<<twopow[i]<<endl;
}
for(ri i=2;i<=100002;i++){
inv[i]=(ll)inv[i]*inv[i-1]%p;//比较神奇,逆元的阶乘是原来数的阶乘的逆元
}
return ;
}
int t;
inline int solve(int m,int n){
if(m0)return twopow[n];
if(n==m)return 1;
return (ll)fac[n]inv[n-m]%ptwopow[n-m]%p*inv[m]%p;
}
int main(){
int n,m;
read(t);
pre();
while(t--){
read(n),read(m);
printf("%d\n",solve(m,n));
}
return 0;
}
```
Yali7月集训Contest2 T1 Cube 题解的更多相关文章
- Contest2037 - CSU Monthly 2013 Oct(中南大学2013年10月月赛水题部分题解)
Problem A: Small change 题解:http://www.cnblogs.com/crazyapple/p/3349469.html Problem B: Scoop water 题 ...
- FJ省队集训DAY4 T1
直接上题解 #include<cstdio> #include<iostream> #include<cmath> #include<cstring> ...
- FJ省队集训DAY3 T1
思路:我们考虑如果取掉一个部分,那么能影响到最优解的只有离它最近的那两个部分. 因此我们考虑堆维护最小的部分,离散化离散掉区间,然后用线段树维护区间有没有雪,最后用平衡树在线段的左右端点上面维护最小的 ...
- 集训day15 t1 poj3728
[问题描述] 有一颗n个节点的树 每个节点上都有许多奸商在卖东西,第i个奸商的理想价格为vi,即他会以vi的价格购买或卖出一件东西 有m个人希望从树上的某个点走到另一个点,问你在只进行一次买卖(每次仅 ...
- 洛谷 4932 洛谷10月月赛II T1 浏览器
[题解] x xor y的结果在二进制下有奇数个1,等价于x与y在二进制下的1的个数之和为奇数,因为x xor y减少的1的个数一定是偶数(两个数这一位都为1,xor的结果为0,减少了2个1) 那么答 ...
- 2020牛客寒假算法基础集训营5 部分题解(BDEH)
B: 牛牛战队的比赛地(二分做法)题意:二维平面给定n个点,在x轴找一点使得到n个点距离的最大值最小. 思路:我们可以将问题转化为在x轴找到一个圆心,使得该圆包含这n个点且半径最小,这样就变成了最小圆 ...
- NOI Online #3 提高组 T1水壶 题解
题目描述 有 n 个容量无穷大的水壶,它们从 1∼n 编号,初始时 i 号水壶中装有 Ai 单位的水. 你可以进行不超过 k 次操作,每次操作需要选择一个满足 1≤x≤n−1 的编号 x,然后把 x ...
- 模拟赛18 T1 施工 题解
前言: 真的是不容易啊.这个题在考场上想到了最关键的性质,但是没写出来. 后来写出来,一直调,小错不断. 没想到改的最后一个错误是两个int 乘起来爆了int 其实最后我还是觉得复杂度很假.\(n^2 ...
- FJ省队集训DAY5 T1
思路:考试的时候打了LCT,自以为能过,没想到只能过80.. 考完一想:lct的做法点数是100W,就算是nlogn也会T. 讲一下lct的做法把:首先如果一条边连接的两个点都在同一个联通块内,那么这 ...
随机推荐
- 黑马vue---20、v-if和v-show的使用和特点
黑马vue---20.v-if和v-show的使用和特点 一.总结 一句话总结: v-if 的特点:每次都会重新删除或创建元素 v-show 的特点: 每次不会重新进行DOM的删除和创建操作,只是切换 ...
- [java]取当前平台默认字符集,取字符串长度
public class TimestampLength { public static void main(String[] args) { System.out.println(java.nio. ...
- spring clound gateway 上传文件,中文文件名乱码解决办法
先说解决办法吧: 有三种解决办法 1 ,zuul官方给出了解决方案,使用/zuul开头的请求可以避免中文名乱码以及支持大文件上传 域名是 testgateway.com 接口是 api/image ...
- 在Android初次的前期学习中的十二个小例子(附案例下载)
目录(点击标题即可下载): Hello:使用Intent在两个Activity之间切换 Hello2:实现特定的鼠标点击事件功能 Hello3:点击监听事件集中处理 Hello4:登录注册界面布局 H ...
- openstack思维导图
RABBITMQ memcache keystone glance nova neutron cinder horizon
- Linux md5sum 命令
Linux md5sum 命令 通过 Linux 的 md5sum 命令,可以对指定的文件,计算出唯一的一个MD5值(128bit). 通过比较文件前后的MD5值,可以判断文件是否发生变化(是否被修改 ...
- JAVA 基础编程练习题3 【程序 3 水仙花数】
3 [程序 3 水仙花数] 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身.例 如:153 是一个"水仙 ...
- idea 中的new file 没有jsp
idea 的new file中没有你需要的文件,原因是IDEA认为当前包下不应该创建该文件,以就没有创建该文件的选项. 以jsp 文件为例.其他文件类似. 解决方法: File ---> pro ...
- python基础知识(循环语句)
for循环.while循环.循环嵌套 for 迭代变量 In 对象: 循环体 range(start,end,step) 第一个和第三个可以省略生成一系列的连续整数 start 包括起始值 end ...
- Dlib支持CPU指令集编译问题(SSE4.2或者AVX)
The compile script is: mkdir build cd build cmake ../../tools/python -DUSE_SSE2_INSTRUCTIONS=ON cmak ...