当前位置: 首页 > wzjs >正文

公司可以做网站iis网站正在建设中

公司可以做网站,iis网站正在建设中,长沙网站建设搭建,网站如何解除绑定域名Sugar Sweet II - Problem - QOJ.ac 显然第i个小朋友得到的糖果数量期望应该是a[i]w[i]*pi,其中pi是事件i发生的概率 对于i事件分类讨论: 1.如果第bi小朋友的初始糖果数量已经大于i当前的糖果数量,即a[b[i]] > a[i],说明i事件必然发生,概率为1 2.如…

Sugar Sweet II - Problem - QOJ.ac

显然第i个小朋友得到的糖果数量期望应该是a[i]+w[i]*pi,其中pi是事件i发生的概率

对于i事件分类讨论:

1.如果第bi小朋友的初始糖果数量已经大于i当前的糖果数量,即a[b[i]] > a[i],说明i事件必然发生,概率为1

2.如果第bi小朋友的最大糖果数量<=i当前的糖果数量,a[b[i]] + w[b[i]] <= a[i],说明i事件不可能发生,概率为0

3.否则i事件可能发生,发生的前提是bi事件发生

对于第3种情况,对bi->i连边,从节点i开始向上追溯。当遇到第一个必然发生或不可能发生的事件j时停止查找:若j为必然发生事件,则i的发生概率为1/(i到j距离的阶乘)。这是因为i的发生需要严格遵循从j开始的依赖链顺序,其概率等于这些依赖节点所有合法排列数的倒数;若j为不可能发生事件,则i发生的概率为0。

打个比方:

对于样例:

n = 3

a: 5 4 3

b: 2 3 1

w: 1 2 3 

连边,如图

假如1事件要发生,则必须2事件要发生,2事件要发生,则必须3事件要发生,因为3事件是必然发生事件(a[1]=5>a[3]=3),所以1事件可能发生,发生的概率是3先发生,2再发生,1再发生。也就是1/3*1/2*1/1。

把这个样例改一下:
 

n = 3

a:  4  4  2
b:  2  3  2
w:  1  1  1

如图

假如1事件要发生,则必须2事件发生,而2事件不可能发生,所以1事件也不可能发生,概率为0

预处理阶乘,记录pi答案为长度值。为避免将本该概率为0的事件设为长度值,我们直接设定必然事件i的答案值为1。然后从必然事件开始向下查找,将后续答案更新为前一答案加1。

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define pii pair<int, int>
const int N = 1E6 + 10;
const int mod = 1e9 + 7;
int fac[N];
int qmi(int a, int b, int p)
{int res = 1;while (b){if (b & 1)res = res * a % p;b >>= 1;a = a * a % p;}return res;
}
void init()
{fac[0] = 1;for (int i = 1; i < N; i++)fac[i] = (fac[i - 1] * i) % mod;fac[0] = 0;
}
int a[N], b[N], w[N];
vector<int> e[N];
int res[N];void dfs(int u)
{for (int v : e[u]){res[v] = res[u] + 1;dfs(v);}
}
void solve()
{int n;cin >> n;for (int i = 1; i <= n; i++)cin >> a[i], res[i] = -1;for (int i = 1; i <= n; i++)cin >> b[i];for (int i = 1; i <= n; i++)cin >> w[i];for (int i = 1; i <= n; i++){if (a[b[i]] > a[i]) // i事件必然发生,概率为1{res[i] = 1;}else if (a[b[i]] + w[b[i]] <= a[i]) // i事件必然不发生,概率为0{res[i] = 0;}else // i事件可能发生,i事件发生的前提是b[i]事件发生{if (b[i] == i) // 特判自环res[i] = 0;e[b[i]].push_back(i);}}for (int i = 1; i <= n; i++){if (res[i] == 1) // 从必然发生的事件往下找{dfs(i);}}for (int i = 1; i <= n; i++){// cout << res[i] << ' ';e[i].clear();// continue;cout << (a[i] + (w[i] * qmi(fac[res[i]], mod - 2, mod)) % mod) % mod << ' ';}cout << endl;
}signed main()
{init();ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t = 1;cin >> t;while (t--)solve();
}


文章转载自:

http://BteLRYpo.jgnst.cn
http://WLu6bRcT.jgnst.cn
http://C9fqug1A.jgnst.cn
http://eR7xDSVt.jgnst.cn
http://HVsnNkR0.jgnst.cn
http://qi8HlVWu.jgnst.cn
http://LCIY8Vi4.jgnst.cn
http://kw4gNHsv.jgnst.cn
http://yYz2ELWV.jgnst.cn
http://6S8kVY6E.jgnst.cn
http://pZfVf6BZ.jgnst.cn
http://6qf3t1rZ.jgnst.cn
http://Wyyciqy9.jgnst.cn
http://efEpkyjx.jgnst.cn
http://jmwLaaWQ.jgnst.cn
http://qeMQRUTi.jgnst.cn
http://5FMPA3nE.jgnst.cn
http://hQD3IXxP.jgnst.cn
http://4oNmsSnx.jgnst.cn
http://475gAszi.jgnst.cn
http://U8KhMeEP.jgnst.cn
http://2Ifr97xL.jgnst.cn
http://s3JjDyma.jgnst.cn
http://Oz3xrrPW.jgnst.cn
http://aaRWLJCD.jgnst.cn
http://WXgh7D5A.jgnst.cn
http://xITOh6vF.jgnst.cn
http://brJvwUxW.jgnst.cn
http://yNf5uSda.jgnst.cn
http://dSmZ5fxd.jgnst.cn
http://www.dtcms.com/wzjs/632049.html

相关文章:

  • 在那做网站重庆公司建网站流程
  • 农产品信息网站的建设学室内设计培训哪里好
  • 社科联网站建设方案策划书wordpress通过.htaccess实现缓存压缩
  • 做变性手术视频网站企业培训心得
  • windows iis运行php网站灰色词seo推广
  • 网站制作公司 云南企业营销网站建设费用预算
  • 网站中的表格老备案域名购买
  • 网站空间哪家公司的好wordpress最好的插件
  • 自己的网站到期域名如何续费注册人力资源公司需要什么手续
  • 徐州网站建设多少钱wordpress小工具跟随
  • 在电脑上做苗木网站网站图片分辨率
  • 合租网站设计祥云县住房和城乡建设网站
  • dedecms小说网站模板怎么做属于自己的域名网站
  • 网站建设与运营实验购物网站建设容易出现的问题
  • 网站建设与设计实验报告手工制作大全简单
  • 深圳南山网站建设工作室个人主页网站设计代码
  • 网站策划方案实例新闻国际最新消息
  • 网站建设全网推广学做古装网站
  • 网站建设费 科研 类apmserve设置多个网站
  • 汕头自助建站模板长春工程建设信息网站
  • 北京 网站代运营做游戏模型参考的网站
  • 公司建设网站的报告书网站建设怎样才能吸引顾客
  • 广告推广营销网站企业如何打造品牌
  • 虚拟机 网站建设三网合一网站报价
  • 做地区招聘网站网站建设及维护干什么的
  • 南昌网站建设机构无锡网站建设咨询
  • 网站注册流程google ads 推广
  • 颇有名气的网站建设专家好网站开发策划要求
  • 网站免费个人空间申请o2o平台有哪些可以入驻
  • 做网站工作的怎么填职务网站首页优化模板