Codeforces 912 质因数折半 方格数学期望
A
B
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
const double EPS = 1.0e-4;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll Mod = ;
set<int> need;
map<int, bool> mp[];
vector<int> ans;
int main()
{
ll n, k;
cin >> n >> k;
ll cnt = ;
for (ll i = ; i >= ; i--)
{
if ((1LL << i)&n)
{
cnt = i;
break;
}
}
if (k == )
{
cout << n << endl;
}
else
{
cout << (1LL << (cnt + )) - << endl;
}
return ;
}
D
每个点(i,j)在min(i,min(r,n-r+1))*min(j,min(r,m-r+1))个正方形内
这个点的贡献为number*在多少个正方形内/(n-r+1)/(m-r+1)
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
const double EPS = 1.0e-4;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll Mod = ;
ll area;
ll chang, kuang;
ll n, m, r, k;
double anser = ;
map<ll, bool> mp[];
struct node
{
ll x, y, sum;
friend operator<(node a, node b)
{
return a.sum < b.sum;
}
};
priority_queue<node> que;
ll judge(int x, int y)
{
if (x == (n + ) / && (n & ) && y == (m + ) / && (m & ))
{
return ;
}
if ((x == (n + ) / && (n & )) || (y == (m + ) / && (m & )))
{
return ;
}
return ;
}
int main()
{
cin >> n >> m >> r >> k;
chang = min(r, n - r + ), kuang = min(r, m - r + );
area = (n - r + ) * (m - r + );
node cnt;
cnt.x = (n + ) / , cnt.y = (m + ) / , cnt.sum = min(cnt.x, chang) * min(cnt.y, kuang);
que.push(cnt);
while (!que.empty() && k)
{
node cur = que.top();
que.pop();
ll number = judge(cur.x, cur.y);
number = min(number, k);
k -= number;
anser += 1.0 * number * cur.sum / area;
node todo;
todo.x = cur.x - , todo.y = cur.y, todo.sum = min(todo.x, chang) * min(todo.y, kuang);
if (todo.x >= && todo.y >= && mp[todo.x][todo.y] == )
{
que.push(todo);
mp[todo.x][todo.y]++;
}
todo.x = cur.x, todo.y = cur.y - , todo.sum = min(todo.x, chang) * min(todo.y, kuang);
if (todo.x >= && todo.y >= && mp[todo.x][todo.y] == )
{
que.push(todo);
mp[todo.x][todo.y]++;
}
}
printf("%.10f\n", anser);
}
E
给你一个大小为N(N<=16)的集合
然后再给你个N个质数 要求你求第K小的一个满足要求的数 一个数满足要求当且仅当其质因数都在集合内
二分搜索 分成两个集合各自乘积 然后从一个集合的number[0].size()开始 递减 从另外一个 number[1].size()开始递增 用一个cur来维护每个number[0][i]的贡献
因为当最坏的情况时后面的数比前面的大 所以折半的时候前面的集合要适当小一点不然会T
#include <bits/stdc++.h>
#define PI acos(-1.0)
#define mem(a,b) memset((a),b,sizeof(a))
#define TS printf("!!!\n")
#define pb push_back
#define inf 1e9
//std::ios::sync_with_stdio(false);
using namespace std;
//priority_queue<int,vector<int>,greater<int>> que; get min
const double eps = 1.0e-10;
const double EPS = 1.0e-4;
typedef pair<int, int> pairint;
typedef long long ll;
typedef unsigned long long ull;
//const int maxn = 3e5 + 10;
const int turn[][] = {{, }, { -, }, {, }, {, -}};
//priority_queue<int, vector<int>, less<int>> que;
//next_permutation
ll Mod = ;
ll k;
ll limit = 1e18;
ll num[];
double anser = ;
vector<ll> number[];
void dfs(int l, int r, ll x, int pos)
{
number[pos].push_back(x);
for (int i = l; i <= r; i++)
{
if (limit / num[i] >= x)
{
dfs(i, r, x * num[i], pos);
}
}
}
ll check(ll x)
{
ll sum = ;
ll cur = ;
for (int i = number[].size() - ; i >= ; i--)
{
while (cur < number[].size() && number[][cur] <= x / number[][i])
{
++cur;
}
sum += cur;
}
return sum;
}
int main()
{
int n;
cin >> n;
for (int i = ; i <= n; i++)
{
cin >> num[i];
}
sort(num + , num + + n);
cin >> k;
//TS;
dfs(, min(, n), , );
dfs(min(, n) + , n, , );
cout << number[].size() << " " << number[].size() << endl;
//TS;
sort(number[].begin(), number[].end());
sort(number[].begin(), number[].end());
ll l = ;
ll r = 1e18;
while (l < r - )
{
ll mid = (l + r) >> ;
if (check(mid) >= k)
{
r = mid;
}
else
{
l = mid;
}
}
cout << r << endl;
}
Codeforces 912 质因数折半 方格数学期望的更多相关文章
- Codeforces 839C Journey - 树形动态规划 - 数学期望
There are n cities and n - 1 roads in the Seven Kingdoms, each road connects two cities and we can r ...
- Codeforces Round #259(div2)C(数学期望)
数学题. 关键是求最大值为k时有多少种情况,结果是kn-(k-1)n-1.可以这么想:每一次都从1至k里选,共kn种,这里需要再减去每一次都从1至k-1里面选的情况.当然也可以分类计数法:按出现几次k ...
- CodeForces Div1: 995 D. Game(数学期望)
Allen and Bessie are playing a simple number game. They both know a function f:{0,1}n→Rf:{0,1}n→R, i ...
- Codeforces Round #259 (Div. 2) C - Little Pony and Expected Maximum (数学期望)
题目链接 题意 : 一个m面的骰子,掷n次,问得到最大值的期望. 思路 : 数学期望,离散时的公式是E(X) = X1*p(X1) + X2*p(X2) + …… + Xn*p(Xn) p(xi)的是 ...
- 【整理】简单的数学期望和概率DP
数学期望 P=Σ每一种状态*对应的概率. 因为不可能枚举完所有的状态,有时也不可能枚举完,比如抛硬币,有可能一直是正面,etc.在没有接触数学期望时看到数学期望的题可能会觉得很阔怕(因为我高中就是这么 ...
- 2019暑期集训第二讲 - 组合数学&概率&数学期望
A - 容斥原理(CodeForces - 451E) 二进制状态压缩暴力枚举哪几个花选的个数超过了总个数,卢卡斯定理求组合数,容斥原理求答案 可以先把每个花的数量当成无限个,这样就是一个多重集的组合 ...
- 动态规划之经典数学期望和概率DP
起因:在一场训练赛上.有这么一题没做出来. 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6829 题目大意:有三个人,他们分别有\(X,Y,Z\)块钱 ...
- [BZOJ 3143][HNOI2013]游走(数学期望)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=3143 分析: 易得如果知道了每条边经过的数学期望,那就可以贪心着按每条边的期望的大小赋 ...
- 数学期望和概率DP题目泛做(为了对应AD的课件)
题1: Uva 1636 Headshot 题目大意: 给出一个000111序列,注意实际上是环状的.问是0出现的概率大,还是当前是0,下一个还是0的概率大. 问题比较简单,注意比较大小: A/C & ...
随机推荐
- RestTemplate 调用本地服务 connection refused
当需要使用服务间的互相调用的时候,通常来说最优雅的方式莫过于Feign调用了.但是有时候特殊原因还是需要使用httpClient之类的工具. 本次我在使用RestTemplate调用本地服务的时候,会 ...
- activemq 笔记
官网下载好后,修改下conf下activemq.xml配置文件就可以了. 主要将这里的ip改成我们这里用的locahost就可以了: <transportConnectors> <! ...
- 506C Mr. Kitayuta vs. Bamboos
分析 代码 #include<bits/stdc++.h> using namespace std; #define int long long ],h[],now[],cnt[]; in ...
- 歌手详情数据处理和Song类的封装
我们现在每首歌曲的数据都是这样的 我们需要在这个数据里面去提取我们需要的部分,来构造成我们需要的数据对象 那我们要和创建singer.js一样 同样也要创建song.js类 我们还要获取到每首歌对应 ...
- GO开发:etcd用法
etcd是什么? A highly-available key value store for shared configuration and service discovery.是一个键值存储仓库 ...
- 性能测试工具之WebBench
一.简介 WebBench是一款在Linux下使用非常简单的压力测试工具.它的原理是:WebBench首先fork出多个子进程,每个子进程都循环做web访问测试.子进程把访问的结果通过pipe告诉父进 ...
- apue 在 mac 环境编译错误
参考资料:https://unix.stackexchange.com/questions/105483/compiling-code-from-apue 笔者使用 mac 学习 apue, 在编译的 ...
- NeDB——node嵌入式数据库
参考资料1:[http://www.alloyteam.com/2016/03/node-embedded-database-nedb/] 参考资料2:[https://github.com/loui ...
- spring(一) IOC 控制反转 、DI 依赖注入
IOC 控制反转:创建对象的方式 变成了由Spring来主导 IOC底层原理:对象工厂 1.导入jar包:4个核心jar和1个依赖jar spring-beans-4.3.9.RELEASE.jar ...
- 【python+selenium自动化】设置Chrome启动参数
起因:直接用selenium的webdriver启动chrome,会弹出“Chrome正在受到自动软件的控制”,并且窗口较小,是因为chrome没有加载任何配置 解决:点进selenium的Chrom ...