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 & ...
随机推荐
- linux下libusb的安装与测试
0.libusb的介绍:参考[1] 1.环境:vmware_fedora_10(linux-2.6.x) 2.获取源代码:http://sourceforge.net/projects/libusb/ ...
- node.js npm 操作 模块化开发 cnpm镜像安装
模块(包) 传统引入 js 的缺点 整个网页,我们写了一个 js 文件,所有的特效都在里面 耦合度太高,代码之间关联性太强,不便于后期维护 变量容易 全局污染 如果将 复杂的 js 文件,拆成多个功能 ...
- 使用type在对象方法中调用类方法
type简介 type在Python中的作用是创建一个类. 我们创建类的时候一般会使用这样的方法: # -*- coding:utf-8 -*- class Student(object): coun ...
- Windows下对函数打桩,及Linux类似技术
一个简单的桩实现类: #define JMPCODE_LENGTH 5 //x86 平坦内存模式下,绝对跳转指令长度 #define JMPCMD_LENGTH 1 //机械码0xe9长度 #defi ...
- sql type subtype 统计
select * from testtable; type subtype value a sa 1b sb 1a sb errorb sa errora sb 1b sb 1c sa errorc ...
- 获取当前操作的IFrame 对象的方法
分两种情况:第一种:获取iframe对象的JS函数在父页面上,如下 function getIframeByElement(element){ var iframe; $("iframe&q ...
- IIS Express 使用方法
配置文件位置: "%userprofile%\My Documents\IISExpress\config\applicationhost.config" 站点配置节: <s ...
- 通过vue-router实现组件间的跳转
三.通过VueRouter来实现组件之间的跳转提供了3种方式实现跳转:①直接修改地址栏中的路由地址 <!doctype html> <html> <head> &l ...
- CSS3——提示工具 图片廓 图像透明 图像拼接技术 媒体类型 属性选择器
提示工具 提示框在鼠标移动到特定的元素上显示 设置提示框的位置 给提示框添加箭头 提示框的淡入效果 提示框美化 图片廓 响应式图片廓 图像透明 创建透明图像——悬停效果 ———鼠标放置后———> ...
- kubernetes(k8s)容器编排工具基础概念
Kubernetes (K8s): 中文社区:https://www.kubernetes.org.cn/replication-controller-kubernetes 官网:https://ku ...