take

take
题解参考

题目描述

Kanade has n boxes , the i-th box has p[i] probability to have an
diamond of d[i] size.

At the beginning , Kanade has a diamond of 0 size. She will open the
boxes from 1-st to n-th. When she open a box,if there is a diamond in
it and it’s bigger than the diamond of her , she will replace it with
her diamond.

Now you need to calculate the expect number of replacements.

You only need to output the answer module 998244353.

Notice: If x%998244353=y*d %998244353 ,then we denote that
x/y%998244353 =d%998244353

输入描述:
The first line has one integer n.

Then there are n lines. each line has two integers p[i]*100 and d[i].
输出描述:
Output the answer module 998244353
示例1
输入
复制

3
50 1
50 2
50 3

输出
复制

499122178

备注:

1<= n <= 100000

1<=p[i]*100 <=100

1<=d[i]<=10^9

题意:

有n个箱子,第i个盒子具有p [i]大小为d [i]的钻石的概率。
从1号开始依次打开,如果比手中的宝石大就替换它,计算期望的更换次数
(一开始默认手中钻石为0)

题解:

一旦扯到概率我就感觉好复杂。。。
首先我们要知道期望有可加性的,也就是E(X+Y)=E(X)+E(Y)
所以,所有交换次数的期望就等于每个宝箱打开后交换次数的期望和,而当个宝箱交换次数无非是0或1(即交换与不交换),所以如果一个宝箱能够产生交换次数的话,就会对答案产生贡献了
所以我们就要去看每一个宝箱到底能否做出贡献,这怎么看?交换的情况是当前的宝石更大,但是在此宝箱之前可以有更大的宝石,那我们就要使该宝箱打开后不出现宝石就可以了
总结下,对于每个宝箱,我们使在其之前拥有比当前宝箱更大的钻石的宝箱打开后不出现钻石

在这里插入图片描述
式子如图
如果来

代码:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod=998244353;
const int maxn=1e5+10;
int c[maxn];
struct node
{int d,id;ll p;bool operator<(const node &a)const{if(d==a.d) return id<a.id;return d>a.d;}
}q[maxn];int lowbit(int x)
{return x&(-x);
}
void add(int p,ll v)
{while(p<=maxn){c[p]=(c[p]*v)%mod;p+=lowbit(p);}
}ll sum(int p)
{ll res=1;while(p){res=(res*c[p])%mod;p-=lowbit(p);}return res;
}ll quickpow(ll a,ll b,ll m)
{a=a%m;ll ans=1;while(b){if(b&1) ans=(ans*a)%mod;b>>=1;a=(a*a)%mod;}return ans;
}
int main()
{int n;scanf("%d",&n);ll inv=quickpow(100,mod-2,mod);for(int i=1;i<=maxn;i++) c[i]=1;for(int i=1;i<=n;i++){scanf("%lld %d",&q[i].p,&q[i].d);q[i].p=(q[i].p*inv)%mod;q[i].id=i;}sort(q+1,q+n+1);ll ans=0;for(int i=1;i<=n;i++){ans=(ans+(1LL*sum(q[i].id)*q[i].p%mod))%mod;add(q[i].id,(1-q[i].p+mod)%mod);}printf("%lld\n",ans);
}

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

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

相关文章

将传统 ASP.NET 应用迁移到 .NET Core

点击蓝字关注我现在越来越多的人在谈论. NET Core。诚然&#xff0c;.NET Core 是未来, 但是.NET Framework 仍在支持, 因为大量的应用程序无法在短时间内迁移。.NET Core 和 .NET Framework 就像电动汽车和汽油动力汽车。汽油车是成熟的&#xff0c;你可以毫无任何问题驾驶它&…

CF932G-Palindrome Partition【PAM】

正题 题目链接:https://www.luogu.com.cn/problem/CF932G 题目大意 给出一个长度为nnn的字符串&#xff0c;将其分为kkk段&#xff08;kkk为任意偶数&#xff09;&#xff0c;记为ppp。要求满足对于任意iii都有pipk−i1p_ip_{k-i1}pi​pk−i1​。求方案数。 1≤n≤1061\leq n…

2018 ACM ICPC Asia Regional - Seoul B.Cosmetic Survey

参考大佬代码 题目大意 nnn个顾客&#xff0c;mmm种画妆品&#xff0c;每一个顾客会给mmm种化妆品一个值&#xff0c;这个值代表这个化妆品在他心中的排名&#xff0c;排名越小越喜欢&#xff0c;如果这个值为0说明最不喜欢这一种化妆品&#xff08;值为0理解为无穷大&#xf…

The table(CF226D)

正题 CF226D 题目大意 给一个n*m的矩阵&#xff0c;每次操作可以使一行或一列全部变号&#xff08;变-&#xff0c;-变&#xff09;&#xff0c;问如何操作可以使所有行列之和都是正数 解题思路 考虑每次暴力找小于0的一行或一列&#xff0c;然后反转 因为每次反转肯定会使…

[翻译] 初看 ASP.NET Core 3.0 即将到来的变化

原文: A first look at changes coming in ASP.NET Core 3.0在我们努力完成下一个 minor 版本的 ASP.NET Core 的同时&#xff0c;我们也在对下一个 major 版本进行更新&#xff0c;其中包括如何使用框架组合项目、更紧密的 .NET Core 集成以及第三方开源集成&#xff0c;所有这…

数字串

来源&#xff1a;牛客网&#xff1a; 题目描述 一个只含数字的字符串&#xff0c;q次操作&#xff0c;每次操作将第i位数字改为x&#xff0c;每次操作后&#xff0c;统计长度在[l, r]之间且首数字大于尾数字的子串的个数。 输入描述: 第一行一个只含数字的字符串&#xff1b…

【随机】Kuroni and the Punishment(CF1305F)

正题 luogu CF1305F 题目大意 给你n个数&#xff0c;每次操作可以使一个数1或-1&#xff0c;让你用最小的操作数使所有数的gcd>1 解题思路 显然把所有数都修改为偶数可以得到 2|gcd&#xff0c;且步数 ≤n\leq n≤n 对于其它方案&#xff0c;至少有一半的数修改次数小于…

hdu5909-Tree Cutting【FWT】

正题 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid5909 题目大意 给出nnn和mmm&#xff08;m2km2^km2k&#xff09;。再给出一个大小为nnn的树&#xff0c;每个点有点权&#xff0c;对于每个i∈[1,m)i\in[1,m)i∈[1,m)求有多少个联通子图的点权异或和为iii 1≤T≤10…

codeforces1455 D. Sequence and Swaps

昨天晚上巨困&#xff0c;就没有打&#xff0c;今天课间的时候就看了一下D题&#xff0c;发现好像可以瞎搞&#xff0c;于是吃完饭就写了一下&#xff0c;调过样例一次就A了qaq。 D. Sequence and Swaps 枚举贪心 由于数据范围n≤500n\leq500n≤500&#xff0c;由此我们可以在…

珂朵莉的数列

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给了你一个序列&#xff0c;有n(n1)/2 ​ 个子区间&#xff0c;求出她们各自的逆序对个数&#xff0c;然后加起来输出 输入描述: 第一行一个数 n 表示这个序列 a 的长度 之后一行 n 个数&#xff0c;第i个数表示ai 输出…

aspnet core 2.1中使用jwt从原理到精通二

在aspnet core中&#xff0c;自定义jwt管道验证有了上一节的内容作为基础&#xff0c;那这点也是非常容易的&#xff0c;关键点在中间件&#xff0c;只是把上一级在测试类中的自定义验证放到中间件中来即可&#xff0c;不过需要注意&#xff1a;中间件 的位置很重要&#xff0c…

【线段树】Traffic Jams in the Land(CF498D)

正题 luogu CF498D 题目大意 给n个1-6的数&#xff0c;让你进行以下操作&#xff1a; 修改其中一个数从第x个数走到第y个数&#xff08;x≤yx\leq yx≤y&#xff09;&#xff0c;到达一个点时&#xff0c;如果当前时间能被该数整除&#xff0c;那么时间2&#xff0c;否则1&a…

P4201-[NOI2008]设计路线【结论,树形dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4201 题目大意 给出nnn个点的一棵树开始所有边都是白色&#xff0c;选出若干条没有公共点的路径将上面所有边变为黑色。 要求所有点到111号点的路径上经过的白色边的数量的最大值最小。 求最小值和方案数 解题思路 直接记…

codeforces1453 D. Checkpoints

以为又要掉分了&#xff08;结果没掉说明太菜了&#xff09;&#xff0c;写完ABC还有45分钟&#xff0c;推式子一直没啥结果&#xff0c;最后10分钟想到D题的一个性质&#xff0c;可惜没时间了~ D. Checkpoints Heltion大佬题解 性质&#xff1a;把形如100…01 \ 0 \ 0 \dots…

CentOS开发ASP.NET Core入门教程

因为之前一直没怎么玩过CentOS&#xff0c;大多数时间都是使用Win10进行开发&#xff0c;然后程序都部署在Window Server2008或者Window Server2012上&#xff01;因此想尝试下Linux系统。最后经过选型选了比较流行的CentOS系统。正好&#xff0c;今晚要加班&#xff0c;所以在…

Java的学习与java大数运算

之前就学过一点java&#xff0c;但太久没用知识点早就还给书本&#xff0c;之前在实验室搞到一本java的书&#xff0c;今天来重新温习一下 java的语法大部分和c语言是一样的&#xff0c;入门非常快&#xff0c;所以在这里基础语句的用法就省略了 输出&#xff1a; System.out.…

【DP】【容斥】Nice to Meet You(AT3634)

正题 luogu AT3634 题目大意 给你一个图&#xff0c;让你给图上的边定方向&#xff0c;问1,2两个点可以到同一个点的方案数 解题思路 直接求可以到同一个点不好求&#xff0c;可以用总方案数减去不合法方案数&#xff0c;即到不了同一个点的方案数 那么就是有若干点把1,2分…

codeforces1453 E. Dog Snacks

E. Dog Snacks Heltion大佬题解 fuf_ufu​表示节点uuu到最近叶子节点的距离。 首先不难发现&#xff0c;考虑一棵子树根节点为uuu&#xff0c;一定每次都把一整棵子树上的食物吃完&#xff0c;然后再去别的子树。 由于每次狗总是先去离他最近的节点&#xff0c;如果我们把一…

工厂参观记:.NET Core 中 HttpClientFactory 如何解决 HttpClient 臭名昭著的问题

在 .NET Framework 与 .NET Core 中 HttpClient 有个臭名昭著的问题&#xff0c;HttpClient 实现了 IDispose 接口&#xff0c;但当你 Dispose 它时&#xff0c;它不会立即关闭所使用的 tcp 连接&#xff0c;而是将 tcp 连接置为 TIME_WAIT 状态&#xff0c;240秒&#xff08;4…

数据结构题(莫队算法)

数据结构题 题目&#xff1a; 问在区间[l,r]和[l1,r1]内x的出现次数的乘积是多少&#xff1f; 题解&#xff1a; 莫队算法的模板题 关于莫队算法你可以参考这个 我这里简单的说说我对莫队的理解&#xff1a; 莫队是一个优雅的暴力&#xff0c;就是将原本复杂度不能过的程序…