首页 > 其他分享 >P5520 [yLOI2019] 青原樱

P5520 [yLOI2019] 青原樱

时间:2024-07-20 15:18:45浏览次数:22  
标签:P5520 yLOI2019 ll 青原 long ans type

原题链接

题解

设花为 1 ,花盆为 0,我们先确保花之间有空隙,即 \(1010....0101\)

接下来再插入 \(n-m-(m-1)\) 个花盆进入 1 与 1 之间

则有 \(C_{n-m+1}^{m}\) 种插法(相当于m个黑球,n个白球有几种排列方法)

再乘上 \(A_m\) ,即花与花之间排列

所以答案为 \(A_{n-m+1}^m\)

注意,什么是A排列搞清楚!!!

code

#include<bits/stdc++.h>
#define ll long long
using namespace std;

ll type,n,m,p;

void solve()
{
    cin>>type>>n>>m>>p;

    ll ans=1;
    for(ll i=n-m+1;i>=n-m-m+2;i--) ans=ans*i%p;
    cout<<ans;
}
int main()
{
    ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
    int t=1;
    //cin>>t;
    while(t--) solve();
    return 0;
}


标签:P5520,yLOI2019,ll,青原,long,ans,type
From: https://www.cnblogs.com/pure4knowledge/p/18313170

相关文章

  • 青原樱
    正常人的思路我的思路:我们假设已经得到了一种方案,我们将这种方案具体化,对每一种树所在的花盆的位置编号。比如13468代表五棵树分别种在了第\(1,3,4,6,8\)号花盆里面那么显然,我们对序列的\(a_i\)减去\(i\),如果得到的新的序列是一个严格单增序列,那么原来的序列就是合法的新......
  • P5521 [yLOI2019] 梅深不见冬
    看题目可以发现每个点的需求需要看它儿子所需要的值,所以就可以理所当然的想到将所有的点的儿子节点加在一起,然后排序,让大的先处理,所以我们就得到了一分美好的代码。#include<cstdio>#include<vector>#include<queue>usingnamespacestd;constintN=1e5+9;intn;ve......
  • Luogu P5520 [yLOI2019] 青原樱
    考虑先不种花,先算出“花之间空位的可行方案数”\(tot\),乘上花的排列的贡献就能算出答案,即\(tot\timesm!\)为答案所以只需算出“花之间空位的可行方案数”能发现,设\(x_i\)为第\(i\)朵花与第\(i-1\)朵花之间空位的数量,其中设第\(0\)朵花在\(0\)的位置,则发现会有以......