icpc网络赛第二场K Meal

icpc网络赛第二场K Meal

题意:

有n个人,n个菜,
现在n个人轮流吃菜,起初S中有n个菜,第i个人会在还没拿走的菜中随机选一个,拿走第j个菜的概率为ai,j∑k∈Sai,k\frac{a_{i,j}}{\sum_{k∈S}a_{i,k}}kSai,kai,j,然后将这个菜从集合S中删除,如果S为空则结束,否则轮到下一个继续拿菜
让你输出第i个人拿第j个菜的概率
n<=20 ,ai,ja_{i,j}ai,j<=100

题解:

比赛时想好大体思路,好不容易把A写完,调了半天,最后没时间做K了
题意很好理解,对于不同的拿取方式,对于第i个人的情况是不同的,不难看出n很小才20,所以我们可以状压dp
我们枚举二进制,1表示这个菜被取了,0表示还未取
对于一个状态state,假设共cnt个位置为1,因为是顺序吃菜,所以就是求第cnt个人的吃菜概率,枚举其中为1的位置,相当于是吃的第j种菜
用f[i]表示当前这个选菜局面的概率,i的二进制状态下表示菜的选取情况
利用之前的f[]来转移现在的ans[][],用现在的选取状态来更新当前的f[]
这样得到转移方程:

ans[cnt][j]=(ans[cnt][j]+f[i^(1ll<<j)]*a[cnt][j]%mod*inv[sum[cnt]-tot+a[cnt][j]])%mod;
f[i]=(f[i]+f[i^(1ll<<j)]*a[cnt][j]%mod*inv[sum[cnt]-tot+a[cnt][j]])%mod;

这样复杂度为O(n*2n),注意因为a很小,所以求逆元不要用快速幂,会超时,直接O(n)预处理好即可

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define int long long
#define x first
#define y second
typedef pair<int,int> pii;
const int N=21;int dp[N][1<<N];
int  a[N][N];
int f[1<<N];
int ans[N][N];
int sum[N];
int inv[30000000];
const int mod= 998244353;
int qmi(int a,int b)
{int res=1;while(b){if(b&1)	res=res*a%mod;b>>=1;a=a*a%mod;}return res;
}
void init(){inv[1]=1;for(int i=2;i<=2000;++i)inv[i]=mod-(long long)mod/i*inv[mod%i]%mod;
}
signed main()
{int n;cin >> n;init();for(int i=1;i<=n;i++)	{for(int j=0;j<n;j++)	cin >> a[i][j],sum[i]=(sum[i]+a[i][j])%mod;}f[0]=1;for(int i=1;i<1<<n;i++){int cnt=0;int tot=0;for(int j=0;j<n;j++)if(i>>j&1)	cnt++;for(int j=0;j<n;j++)if(i>>j&1)	tot=(tot+a[cnt][j])%mod;for(int j=0;j<n;j++){if(i>>j&1){
//				cout<<"sum[cnt]-?tot+a[cnt][j]="<<sum[cnt]-tot+a[cnt][j]<<endl;ans[cnt][j]=(ans[cnt][j]+f[i^(1ll<<j)]*a[cnt][j]%mod*inv[sum[cnt]-tot+a[cnt][j]])%mod;f[i]=(f[i]+f[i^(1ll<<j)]*a[cnt][j]%mod*inv[sum[cnt]-tot+a[cnt][j]])%mod;}}	
//		cout<<f[i]<<endl;}for(int i=1;i<=n;i++){for(int j=0;j<n;j++)if(j==0)cout<<ans[i][j];else cout<<" "<<ans[i][j];cout<<endl;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/316061.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 Docker 在 Linux 上托管 ASP.NET Core 应用程序

说在前面在阅读本文之前&#xff0c;您必须对 Docker 的中涉及的基本概念以及常见命令有一定了解&#xff0c;本文侧重实战&#xff0c;不会对相关概念详述。同时请确保您本地开发机器已完成如下安装&#xff1a;Docker 18.06 或更高版本的 Docker 客户端.NET Core SDK 2.2 或更…

ICPC网络赛第二场G Limit

ICPC网络赛第二场G Limit 题意&#xff1a; 给你数组a和b&#xff0c;求解&#xff1a; 1≤n≤100000,−100≤ai,bi≤100,0≤t≤5.1≤n≤100000,−100≤a_{i},b_{i}≤100,0≤t≤5.1≤n≤100000,−100≤ai​,bi​≤100,0≤t≤5. 题解&#xff1a; 要用到洛必达来做&#xf…

[VSCode插件推荐] REST Client: 也许是比Postman更好的选择

在测试REST API的时候&#xff0c;想必大家都会有不同的工具选择。如果是基于CLI的话&#xff0c;大家应该会选择cURL。如果是GUI工具的话&#xff0c;相信很多人都会使用Postman。不过今天&#xff0c;笔者要推荐的是REST Client插件。也许&#xff0c;它是比Postman更好的选择…

Codeforces Round #691 (Div. 2)

Codeforces Round #691 (Div. 2) 题号题目知识点ARed-Blue Shuffle签到BMove and Turn(规律结论题)CRow GCD思维DGlass Half Spilled背包ELatin Square思维FFlip and Reverse

.Net资讯 | 一大波开发者福利来了, 一份微软官方Github上发布的开源项目清单等你签收...

目录微软Github开源项目入口微软开源项目受欢迎程度排名Visual Studio CodeTypeScriptRxJS.NET Core 基础类库CNTKMicrosoft calculatorMonaco editorMS-DOSRedis windows版.NET Core CLR (公共语言运行时)ASP.NET CoreEntity Framework CorePowerShell如何在其中搜索自己需要的…

Codeforces Round #691 (Div. 1)

Codeforces Round #691 (Div. 1) 题号题目知识点ARow GCD思维BGlass Half Spilled背包问题CLatin Square思维DFlip and ReverseENim ShortcutsFRange Diameter Sum

C#位运算实际作用之操作整型某一位

1.前言前几天写了两篇关于c#位运算的文章c#位运算基本概念与计算过程C#位运算实际运用在文中也提到了位运算的实际作用之一就是合并整型&#xff0c;当时引用了一个问题&#xff1a;C# 用两个short&#xff0c;一个int32拼成一个long型&#xff0c;高16位用short&#xff0c;中…

CF1458B Glass Half Spilled

CF1458B Glass Half Spilled 题意&#xff1a; 有n杯水&#xff0c;第i杯有容积aia_{i}ai​单位&#xff0c;初始时装有bib_{i}bi​单位的水 现在你可以进行若干次操作,每次选择一杯水的一定水量并倒到另一杯水中,但是因为这些杯子形状非常奇怪,因此每倒一次水,倒的水会有一半…

2019 微软Build大会预告:值得开发者期待的是哪些?

北京时间 5 月 2 日上午 10:00&#xff08;太平洋时间 5 月 1 日晚 19:00&#xff09;&#xff0c;微软通信部门副总裁 Frank Shaw 通过网络提前预告了即将于两天后在美国西雅图召开的 2019 年微软 Build 大会的重点发布与相关信息。InfoQ 记者对本次提前发布做了简要摘录&…

线性时间选择--用于解决第k大(小)元素问题(未补)

线性时间选择–用于解决第k大(小)元素问题

使用高性能Pipelines构建.NET通讯程序

.NET Standard支持一组新的API&#xff0c;System.Span, System.Memory&#xff0c;还有System.IO.Pipelines。这几个新的API极大了提升了.NET程序的效能&#xff0c;将来.NET很多基础API都会使用它们进行重写。Pipelines旨在解决.NET编写Socket通信程序时的很多困难&#xff0…

全球开发者的年度盛宴:微软全球开发者大会 Build 2019邀您一同加入

一年一度的微软全球开发者大会&#xff08;Build&#xff09;将于5月6日至8日在美国西雅图举办。本届大会将围绕全球当下的热门技术展开&#xff0c;包括人工智能、机器学习、容器、DevOps、物联网、混合现实以及Power Platforms等&#xff1b;微软热爱开发者、重视开发者&…

Codeforces Round #688 (Div. 2)

Codeforces Round #688 (Div. 2) 题号题目知识点-ACancel the Trains签到(题解)BSuffix Operations思维CTriangles思维(略)DCheckpointsEDog SnacksFEven Harder

Oracle杀死Java EE:名正言顺转到.NET Core

Eclipse 基金会执行董事 Mike Milinkovich 昨日在博客发表了 Oracle 与 Eclipse 基金会之间关于 Java 商标谈判的结果 —— 双方的谈判最后以失败告终&#xff0c;Oracle 拒绝出让 Java 商标。Mike 在博客中还提及了 Eclipse 基金会和 Oracle 之间关于 Jakarta EE 的协议、Java…

cf1453B. Suffix Operations

cf1453B. Suffix Operations 题意&#xff1a; 给你一个整数序列&#xff0c;其中有n个元素。你需要对这个序列进行操作。 1 在所有操作开始前&#xff0c;你可以选择一个数&#xff0c;并修改他的值&#xff0c;这个值你可以自己定。本操作无花费。 2 选择一个下标i&#…

程序员修神之路--redis做分布式锁可能不那么简单

点击上方“蓝字”带你去看小星星菜菜哥&#xff0c;复联四上映了&#xff0c;要不要一起去看看&#xff1f;又想骗我电影票&#xff0c;对不对&#xff1f;呵呵&#xff0c;想去看了叫我呀看来你工作不饱和呀哪有&#xff0c;这两天我刚基于redis写了一个分布式锁&#xff0c;很…

CF1548A Web of Lies

CF1548A Web of Lies 题意&#xff1a; 题解&#xff1a; 第一感觉是先建边然后跑dfs&#xff0c;但是看数据范围肯定不对&#xff0c;现在我们开始考虑其中的性质 对于第三个操作&#xff0c;我们是要将所有>2的连通块进行判断的&#xff0c;我们考虑对于编号为x的点&…

Abp CLI 上线

Abp vNext CLI 工具随着0.17.0版本的发布已经上线.Abp中文网第一时间制作 Cn.Abp.Cli 工具. 目前提供下载加速, 后续Abp中文网CLI将会提供更多本土化功能, 并随时与官方CLI代码同步.源码(查看原文): https://github.com/cnAbp/abp-cli原文地址&#xff1a;https://mp.weixin.qq…

如何正确地生成一个随机数

参考文章 笔记 | 如何正确地生成一个随机数 CF曾提到&#xff1a;Don’t use rand(): a guide to random number generators in C 文章总结&#xff1a; 1 .rand()的随机范围太小了&#xff0c;在某些平台下&#xff08;例如 Windows&#xff09;RAND_MAX 只有 32768。如果需要…

一篇短文带您了解一下EasyCaching

前言从2017年11月11号在Github创建EasyCaching这个仓库&#xff0c;到现在也已经将近一年半的时间了&#xff0c;基本都是在下班之后和假期在完善这个项目。由于EasyCaching目前只有英文的文档托管在Read the Docs上面&#xff0c;当初选的MkDocs现在还不支持多语言&#xff0c…