Codeforces Beta Round #62

A Irrational problem

题意

f(x) = x mod p1 mod p2 mod p3 mod p4

问你[a,b]中有多少个数满足f(x)=x

题解

显然直接带进去就好了……

代码

#include<bits/stdc++.h>
using namespace std; int main()
{
int p1,p2,p3,p4,a,b;
scanf("%d%d%d%d%d%d",&p1,&p2,&p3,&p4,&a,&b);
int ans = 0;
for(int i=a;i<=b;i++){
if(i%p1%p2%p3%p4==i)
ans++;
}
cout<<ans<<endl;
}

B - Energy exchange

题意

你可以把能量从一个位置转移到另外一个位置,但会损失k%能量。

你想要所有最后的能量都是一样的,问你是多少

题解

二分答案就好了……

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e4+7;
int n,k;
double a[maxn];
int main()
{
scanf("%d%d",&n,&k);
for(int i=0;i<n;i++)
scanf("%lf",&a[i]);
double l=0,r=1e6;
for(int i=0;i<100;i++){
double mid=(l+r)/2.0;
double s = 0;
for(int j=0;j<n;j++){
if(a[j]>mid){
s+=1.0*(100-k)*(a[j]-mid)/100.0;
}else{
s-=(mid-a[j]);
}
}
if(s<0)r=mid;
else l=mid;
}
printf("%.12f\n",l);
}

C. Synchrophasotron

题意

给你一些管道,必须从小的管道流到大的管道,且如果流过flow的流量的话,那么代价就是a[i]+flow^2

每个管道还有最少流量和最大流量限制。

现在问你一开始1号管道最少有多少水,才能使得所有水都到达n点,且最大的花费是多少

题解

直接暴力dfs就好了,暴力枚举最小值,然后dfs去check,暴力枚举每个水管通过多少的水。

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn = 15;
int l[maxn][maxn],h[maxn][maxn],a[maxn][maxn];
int flow[maxn],n,Max,Min;
void dfs(int x,int y,int cost){
if(x==n){
Max = max(cost,Max);
return;
}
if(y>n){
if(flow[x]==0)dfs(x+1,x+2,cost);
return;
}
for(int i=l[x][y];i<=h[x][y];i++){
if(flow[x]<i)return;
int ncost = cost;
if(i!=0)ncost+=a[x][y]+i*i;
flow[x]-=i;flow[y]+=i;
dfs(x,y+1,ncost);
flow[x]+=i;flow[y]-=i;
}
}
int main()
{
scanf("%d",&n);
for(int i=0;i<n;i++)
for(int j=i+1;j<n;j++){
int A,B;scanf("%d%d",&A,&B);
scanf("%d%d%d",&l[A][B],&h[A][B],&a[A][B]);
}
Max = -1,Min = -1;
for(Min=0;Min<=26;Min++){
flow[1]=Min;
dfs(1,2,0);
if(Max!=-1)break;
}
if(Max==-1)cout<<"-1 -1"<<endl;
else cout<<Min<<" "<<Max<<endl;
}

D. Half-decay tree

题意

给你一个完全二叉树,一共两种操作,第一种操作是使得某个节点的电荷增加k

第二种操作是随机删除掉从某个叶子节点到达根节点的路径,然后输出带电量。

带电量的定义是取所有连通块的带电量的最大值

题解

直接暴力dfs下去,维护子树带电量和这个节点的带电量。

每次树形dp取左边还是取右边,维护一下就好了。

代码

#include<bits/stdc++.h>
using namespace std;
map<int,int>sum,cost;
int h,n;
double solve(int x,double ans){
if(sum[x]<=ans)return ans;
return (solve(x*2,max(ans,1.*cost[x]+sum[x*2+1]))+solve(x*2+1,max(ans,1.*cost[x]+sum[x*2])))/2.0;
}
int main()
{
scanf("%d%d",&h,&n);
for(int i=0;i<n;i++){
string s;
cin>>s;
if(s[0]=='a'){
int a,b;
scanf("%d%d",&a,&b);
cost[a]+=b;
while(a){
sum[a]+=b;
a/=2;
}
}
else{
printf("%.9f\n",solve(1,0));
}
}
}

Codeforces Beta Round #62 题解【ABCD】的更多相关文章

  1. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  2. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  3. Codeforces Beta Round #5 B. Center Alignment 模拟题

    B. Center Alignment 题目连接: http://www.codeforces.com/contest/5/problem/B Description Almost every tex ...

  4. Codeforces Beta Round 84 (Div. 2 Only)

    layout: post title: Codeforces Beta Round 84 (Div. 2 Only) author: "luowentaoaa" catalog: ...

  5. Codeforces Beta Round #17 D. Notepad (数论 + 广义欧拉定理降幂)

    Codeforces Beta Round #17 题目链接:点击我打开题目链接 大概题意: 给你 \(b\),\(n\),\(c\). 让你求:\((b)^{n-1}*(b-1)\%c\). \(2 ...

  6. Codeforces Beta Round #16 E. Fish (状压dp)(概率dp)

    Codeforces Beta Round #16 (Div. 2 Only) E. Fish 题目链接:## 点击打开链接 题意: 有 \(n\) 条鱼,每两条鱼相遇都会有其中一只吃掉对方,现在给你 ...

  7. Codeforces Beta Round #13 C. Sequence (DP)

    题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...

  8. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  9. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

随机推荐

  1. Spring IoC小结

    一. IoC是什么 Ioc—Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想.在Java开发中,Ioc意味着将你设计好的对象交给容器控制,而不是传统的在你的对象 ...

  2. OpenLayers中的图层

    OpenLayers有多个不同的图层类,每一个都可以连接到不同的地图服务器.例如通过Layer.WMS类可以连接到WMS地图服务器,通过Layer.Google类可以连接到谷歌地图服务器.OpenLa ...

  3. 状态伪类选择器(E::selection)

    E::selection选择器:  E::selection{background:#FF6600;  color:#fff;}     //当文字被选中时,背景是红色,文字是白色 E::-moz-s ...

  4. IIS Connection Timeout vs httpRuntime executionTimeout

    IIS Connection Timeout specifies how long, in seconds, should the code wait before timing out from t ...

  5. C++类库介绍

    如果你有一定的C基础可能学起来比较容易些,但是学习C++的过程中又要尽量避免去使用一些C中的思想:平时还要多看一些高手写的代码,遇到问题多多思考,怎样才能把问题抽象化,以使自己头脑中有类的概念:最后别 ...

  6. 备份数据库的时候设置 BufferCount 选项不正确导致 out of memory 的情况

    备份数据库的时候设置 BufferCount 选项不正确导致 out of memory 的情况 今天群里面的东辉兄跟我说备份生产数据库的时候报错 环境: 32位的SQLSERVER2008 机器有1 ...

  7. 关于CSS中清除浮动的方法

    在使用CSS样式时会经常使用到浮动(float),这时如果没有清除浮动就会造成很多怪异的现象,因此对父级元素清除浮动是必须要做的,这样也是书写CSS的一个良好习惯. 目前常用的方法大致有三种. (1) ...

  8. [C#] Timer + Graphics To Get Simple Animation (简单的源码例子,适合初学者)

    >_<" 这是一个非常简单的利用C#的窗口工程创立的程序,用来做一个简单的动画,涉及Timer和Graphics,适合初学者,高手略过~

  9. [ucgui] 子窗口父窗口

    它创建了3个窗口: 第一个作为桌面的子窗口 第二个作为第一个窗口的子窗口 第三个作为第二个窗口的子窗口 窗口创建后,使用WM_ForEachDesc()在其父窗口中移动各个窗口: static voi ...

  10. 一个Java应用,三种字体风格(Java, Windows, Mac),真是蛋疼

    大家看看下面这张图,红色圈起来的是Java难看至极的字体渲染,黄色圈起来的是正常的Windows渲染,绿色是Mac风格的渲染. 其实我感觉正常风格就挺好的,就是看那个Java的Swing菜单,非常不顺 ...