A. Combination Lock

拨密码。。最少次数。。密码最多有1000位。

用字符串存起来,然后每位大的减小的和小的+10减大的,再取较小值加起来就可以了。。。

#include<stdio.h>
#include<math.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<stack>
#define FOR(i,n) for(i=0;i<(n);i++)
#define CLR(a) memset(a,0,sizeof(a))
#define CIN(a) scanf("%d",&a)
typedef long long ll;
using namespace std;
char s1[],s2[];
int main()
{
int n,ans=,i;
scanf("%d",&n);
scanf("%s%s",s1,s2);
for(i=;i<n;i++)
{
ans+=min(max(s2[i],s1[i])-min(s1[i],s2[i]),min(s2[i],s1[i])+-max(s1[i],s2[i]));
}
printf("%d\n",ans);
return ;
}

B. School Marks

给定一个数字序列,长度是n,已知其中的前k个数字,求其他数字,满足每个数字最大是p,数字的总和不超过x,这些数的中位数不小于y。

直接贪心即可。

要满足中位数不小于y即必须满足不超过n/2个数小于y。

先统计已知的数中小于y的数的个数,如果已经有超过n/2个就直接NO了。

如果没有n/2个数的话就一直往里面添加1(因为保证和最小)直到刚好是N/2个,然后往里面添加y直到达到n个数。

 #include<stdio.h>
#include<math.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<stack>
#define FOR(i,n) for(i=0;i<(n);i++)
#define CLR(a) memset(a,0,sizeof(a))
#define CIN(a) scanf("%d",&a)
typedef long long ll;
using namespace std;
int main()
{
int i,n,k,p,x,y,z,s=,xiao=;
scanf("%d%d%d%d%d",&n,&k,&p,&x,&y);
for(i=;i<k;i++)
{
scanf("%d",&z);
s+=z;
if(z<y) xiao++;
}
//printf("sum=%d xiao=%d\n",s,xiao);
int num=;
int ans[];
for(i=k;i<n;i++)
{
if(xiao<n/)
{
ans[num++]=;
s+=;
xiao++;
}
else if(xiao==n/)
{
ans[num++]=y;
s+=y;
}
else {num=-;break;}
}
if(s<=x&&num!=-)
{
for(i=;i<num;i++)
{
if(i!=) printf(" ");
printf("%d",ans[i]);
}
printf("\n");
}
else printf("-1\n");
return ;
}

C. Ice Cave

图中X表示碎冰,点表示完整的冰,每次走过完整的冰时,这块冰就会变成碎冰。走过碎冰之后就会掉下去。。。

给定初始点和目标点,最终要从目标点掉下去。不能原地跳。。。而且初始点一定是X。

直接DFS一遍整张图就可以了。。。走过的点标记为X,没必要回溯。

 #include<stdio.h>
#include<math.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<stack>
#define FOR(i,n) for(i=0;i<(n);i++)
#define CLR(a) memset(a,0,sizeof(a))
#define CIN(a) scanf("%d",&a)
typedef long long ll;
using namespace std;
char M[][];
int x,y,x2,y2;
int n,m;
int dfs(int x,int y)
{
if(x>=n||x<||y>=m||y<) return ;
if(M[x][y]=='X'&&x==x2-&&y==y2-) return ;
if(M[x][y]=='X') return ;
if(M[x][y]=='.') M[x][y]='X';
if(dfs(x-,y))return ;
if(dfs(x+,y))return ;
if(dfs(x,y-))return ;
if(dfs(x,y+))return ;
return ;
}
int main()
{
int i;
scanf("%d%d",&n,&m);
for(i=;i<n;i++)
{
scanf("%s",M[i]);
}
scanf("%d%d",&x,&y);
scanf("%d%d",&x2,&y2);
M[x-][y-]='.';
if(dfs(x-,y-)){printf("YES\n");}
else printf("NO\n"); return ;
}

D. Bad Luck Island

有r个石头,s个剪刀,p个布。他们之间随机相遇,如果石头碰见了剪刀,石头就会把剪刀干掉。剪刀碰见布,就会把布干掉。。布碰见石头的话,也会把石头干掉。每一对相遇的概率是相同的,求他们三种最终活下来的概率。

概率DP。。

任意状态(r,s,p)可以变成三种状态(r-1,s,p)、(r,s-1,p)、(r,s,p-1)。

对于状态(a,b,c) 有p(a,b,c)=(a/sum)*(b/(sum-1))+(b/sum)*(a/(sum-1))的概率是a和b相遇(sum=a+b+c)。

即可求出任意状态转换成以上三种状态的概率。

然后状态转移方程就是:

dp{a,b,c} =
  p(c,a,b)/sump * dp{a-1,b,c}
+p(a,b,c)/sump * dp{a,b-1,c}
+p(b,c,a)/sump * dp{a,b,c-1}

其中sump =p(a,b,c)+p(b,c,a)+p(c,a,b)

结束。。。

 #include<stdio.h>
#include<math.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<stack>
#define FOR(i,n) for(i=0;i<(n);i++)
#define CLR(a) memset(a,0,sizeof(a))
#define CIN(a) scanf("%d",&a)
typedef long long ll;
using namespace std;
double dp[][][][];
double p(int a,int b,int c)
{
int sum=a+b+c;
return (1.0*a/sum)*(1.0*b/(sum-))+(1.0*b/sum)*(1.0*a/(sum-));
}
double DP(int i,int j,int k,int z)
{
if(i==&&j==) return z==;
if(i==&&k==) return z==;
if(k==&&j==) return z==;
if(i==) return z==;
if(j==) return z==;
if(k==) return z==;
if(z==) return -dp[i][j][k][]-dp[i][j][k][];
return dp[i][j][k][z];
}
int main()
{
int a,b,c,i,j,k;
scanf("%d%d%d",&a,&b,&c);
for(i=;i<=a;i++)
for(j=;j<=b;j++)
for(k=;k<=c;k++)
{
double sump=p(i,j,k)+p(j,k,i)+p(k,i,j);
//printf("sump=%lf\n",sump);
dp[i][j][k][]=;
dp[i][j][k][]+=p(k,i,j)/sump*DP(i-,j,k,);
dp[i][j][k][]+=p(i,j,k)/sump*DP(i,j-,k,);
dp[i][j][k][]+=p(j,k,i)/sump*DP(i,j,k-,); dp[i][j][k][]=;
dp[i][j][k][]+=p(k,i,j)/sump*DP(i-,j,k,);
dp[i][j][k][]+=p(i,j,k)/sump*DP(i,j-,k,);
dp[i][j][k][]+=p(j,k,i)/sump*DP(i,j,k-,);
}
printf("%.12lf %.12lf %.12lf\n",DP(a,b,c,),DP(a,b,c,),DP(a,b,c,));
return ;
}

【解题报告】Codeforces Round #301 (Div. 2) 之ABCD的更多相关文章

  1. DFS/BFS Codeforces Round #301 (Div. 2) C. Ice Cave

    题目传送门 /* 题意:告诉起点终点,踩一次, '.'变成'X',再踩一次,冰块破碎,问是否能使终点冰破碎 DFS:如题解所说,分三种情况:1. 如果两点重合,只要往外走一步再走回来就行了:2. 若两 ...

  2. 贪心 Codeforces Round #301 (Div. 2) B. School Marks

    题目传送门 /* 贪心:首先要注意,y是中位数的要求:先把其他的都设置为1,那么最多有(n-1)/2个比y小的,cnt记录比y小的个数 num1是输出的1的个数,numy是除此之外的数都为y,此时的n ...

  3. 贪心 Codeforces Round #301 (Div. 2) A. Combination Lock

    题目传送门 /* 贪心水题:累加到目标数字的距离,两头找取最小值 */ #include <cstdio> #include <iostream> #include <a ...

  4. Codeforces Round #301 (Div. 2)(A,【模拟】B,【贪心构造】C,【DFS】)

    A. Combination Lock time limit per test:2 seconds memory limit per test:256 megabytes input:standard ...

  5. Codeforces Round #301 (Div. 2) D. Bad Luck Island 概率DP

    D. Bad Luck Island Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/540/pr ...

  6. Codeforces Round #301 (Div. 2) C. Ice Cave BFS

    C. Ice Cave Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/540/problem/C ...

  7. Codeforces Round #301 (Div. 2) B. School Marks 构造/贪心

    B. School Marks Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/540/probl ...

  8. Codeforces Round #301 (Div. 2) A. Combination Lock 暴力

    A. Combination Lock Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/540/p ...

  9. 「日常训练」Bad Luck Island(Codeforces Round 301 Div.2 D)

    题意与分析(CodeForces 540D) 是一道概率dp题. 不过我没把它当dp做... 我就是凭着概率的直觉写的,还好这题不算难. 这题的重点在于考虑概率:他们喜相逢的概率是多少?考虑超几何分布 ...

随机推荐

  1. Maven打包命令

    mvn clean 会把原来target目录给删掉重新生成.mvn install 安装当前工程的输出文件到本地仓库,然后打包mvn clean install 先删除target文件夹 ,然后打包到 ...

  2. LA 5713 秦始皇修路

    https://vjudge.net/problem/UVALive-5713 题意: 秦朝有n个城市,需要修建一些道路使得任意两个城市之间都可以连通.道士徐福声称他可以用法术修路,不花钱,也不用劳动 ...

  3. “Too many open files” 小记

    pycharm远程链接centos7开发过程中突然遇到“Too many open files”. 几点记录: 1. 命令:ulimit -n 查看系统配置,其中的 表示每个进程最多能打开8192个文 ...

  4. Dubbo通过注解实现RPC调用

    启动Dubbo服务有2个方式,1是通过xml配置,2是通过注解来实现,这点和Spring相似. 采用XML配置如下:  <?xml version="1.0" encodin ...

  5. play的过滤类怎么实现继承问题

    原文: Example: public class Secure extends Controller {          @Before     static void checkAuthenti ...

  6. Ubuntu 14.04配置虚拟主机

    虚拟主机常用于在一个单独的IP地址上提供多个域名的网站服务.如果有人想在单个VPS的单个IP地址运行多个网站,这是非常有用的.在这个教程中,让我告诉你如何设置在Ubuntu 14.04 LTS的Apa ...

  7. classpath到底指的哪里

    之前一直对classpath不太明白到底指的哪里,今天研究了一下,做个总结.. classpath顾名思义就是指类路径,但是这样解释可能还是不明白,这里拿一个SpringBoot应用编译后生成的tar ...

  8. 十六 web爬虫讲解2—PhantomJS虚拟浏览器+selenium模块操作PhantomJS

    PhantomJS虚拟浏览器 phantomjs 是一个基于js的webkit内核无头浏览器 也就是没有显示界面的浏览器,利用这个软件,可以获取到网址js加载的任何信息,也就是可以获取浏览器异步加载的 ...

  9. IOS-Quartz2D(Paths元素)

    Paths中的几个重要元素 Points void CGContextMoveToPoint (    CGContextRef c,    CGFloat x,    CGFloat y ); 指定 ...

  10. addEventListener 和 onclick 简单比较

    首先说一下addEventListener 语法: element.addEventListener(event, function, useCapture) 这里的event是事件名,functio ...