【每日一题】逆序对

逆序对

https://ac.nowcoder.com/acm/problem/14731

考虑从n个位置任取两个,前面位置放1,后面位置放0.
所以这是一个组合数图片说明
n个位置固定了两个位置了,还剩下n-2个位置,每个位置可以放0或者1,是个幂级数图片说明
所以答案就是图片说明
进行图片说明的除法运算时候,因为模数是个质数,直接用费马小定理即可。
当然了,注意特判n=1的情况,因为对于快速幂只能进行非负数,而幂级数的指数部分当n=1时候为-1

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1e9+7;
ll qpow(ll a, ll b){
    ll ans=1;
    while(b){
        if(b&1) ans=ans*a%mod;
        a=a*a%mod;
        b>>=1;
    }
    return ans;
}
int main(){
    ll n;cin>>n;
    if(n==1) cout<<0<<endl;
    else cout<<((((n%mod*((n-1)%mod))%mod)*(qpow(2ll,mod-2)%mod)%mod)*qpow(2ll,n-2)%mod)%mod<<endl;
    return 0;
}
每日一题 文章被收录于专栏

每日一题专栏

全部评论

相关推荐

看到这个内容真是闹麻了。。。。。。现在有了AI以后很多人面试都会作弊吗?&nbsp;那对老老实实面试的人岂不是不公平....
程序员牛肉:公平那是对小孩子讲的童话故事,成年人的世界只有能不能接受失败的后果。 你要是能接受面试作弊被发现之后多家公司联合永久拉黑的后果,你就搞。
你找工作的时候用AI吗?
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
3
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务