题解 | #Alice and Bob#

Increasing Subsequence

https://ac.nowcoder.com/acm/contest/11166/I

I题

具体看代码里的注释

#include<bits/stdc++.h>
using namespace std;
const int N=5005,mod=998244353;
typedef long long LL;
const double eps=1e-7;

LL a[N],inv[N];
LL n;
LL qsm(LL a,LL n){
    LL res=1;
    while(n){
        if(n&1)res=(LL)res*a%mod;
        a=(LL)a*a%mod;
        n>>=1;
    }
    return res;
}
LL  f[N][N];
int main(){
    cin>>n;
    for(int i=1;i<=n;i++){
        scanf("%d",&a[i]);
    }
    for(int i=1;i<=n;i++)inv[i]=qsm(i,mod-2);
    //记住,这里是往后递推,类似拓扑图
    //逆着写期望DP,这里发现,每一次与上一次的值有关,下标逆着推能够很好的处理游戏轮数
    for(int j=n;j>=0;j--){//这次选择J,从大到小
        LL cnt=0,sum=0;//期望和,也就是这次选择的数大于J,所有期望和,cnt,均等概率
        for(int i=n;i>=0;i--){// 下一次选择的a[i]
            if(a[i]>j)//说明这里已经计算过了
            {
                cnt++;//往前做的时候可以累加大于 J 的下标个数
                sum+=f[j][a[i]];//所有期望和
                sum%=mod;
            }
            else if(a[i]<j){//下一次不可能选择a[i],所以这一次选择a[i],下一次选择J能够更新,
                //这里上一次是J,这一次是a[i]的方案根本不存在
                f[a[i]][j]=1;//这里期望必有 1 ,就是转移到这个状态有一轮,不管这人是谁,选择的是a[i],游戏轮数是1,能否被其他状态转移过来呢?
                if(!cnt)continue;
                f[a[i]][j]+=sum*inv[cnt]%mod;//加上后面他可以转移的,遵循均等的原则
                f[a[i]][j]%=mod;
            }
        }
    }
    LL res=0;
    for(int i=1;i<=n;i++)
        res=(res+f[0][i])%mod;
    //最后第一个也是均等选择的
    res=res*inv[n]%mod;
    cout<<res<<endl;
    return 0;

}

全部评论

相关推荐

关于“实习生工资多少才算正常”,其实并没有一个放之四海而皆准的标准,但如果结合一线城市的生活成本、工作强度以及实习本身创造的价值来看,我个人认为6000&nbsp;元左右应当是一个基本及格线,也就是每天&nbsp;200&nbsp;多元。如果能达到&nbsp;300、400&nbsp;元一天,甚至更高,那无疑是更理想的状态。首先,从现实成本看,房租、通勤、餐饮几乎都是刚性支出。低于这个水平的实习,往往意味着实习生需要用家庭或存款“倒贴”工作,这在长期来看并不合理。实习本质上是学习,但并不等于“廉价劳动力”,更不应该是经济压力的来源。其次,愿意给实习生更高薪资的公司,通常不会是差公司。这至少说明两点:一是公司资金相对充足,不是靠压缩人力成本勉强维持;二是公司认可实习生的价值,希望你真正参与业务、创造产出,而不是只做边角料工作。很多高薪实习往往伴随着更规范的培养体系、更高的信息密度和更真实的项目经验。当然,高工资并不等于一切,但它往往是一个重要信号。能给到&nbsp;300、400&nbsp;元一天甚至更多的公司,往往对效率、能力和长期发展更有追求,也更可能处在一个有前景的赛道中。总结来说,实习工资不仅是钱的问题,更是公司态度、实力和发展前景的体现。在条件允许的情况下,争取一份“付得起你时间”的实习,本身就是一种理性选择。
北国牛马:你是不是忘了你一周只能上五天班,月薪6000那你日薪就得300了,日薪200一个月也就4000,也就刚好覆盖生活成本了
实习生工资多少才算正常?
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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