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. WIN7环境安装informatica 提示 不能创建Domain或者node

    查看infa安装的bat文件install.bat,会发现,它调用的是.\Server\Windows\Disk1\InstData\VM\install.exe.所以,我们在安装执行,右键insta ...

  2. 01_MySQL DQL_基础查询

    DQL,Data Query Language,数据查询 # 基础查询/*语法:select 查询列表 from 表名: 特点:1.查询列表可以是:表中的字段,常量值.表达式.函数,也可以是多个组合2 ...

  3. 配置servlet支持文件上传

    Servlet3.0为Servlet添加了multipart配置选项,并为HttpServletRequest添加了getPart和getParts方法获取上传文件.为了使Servlet支付文件上传需 ...

  4. jquery validate检验

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  5. Global.asax详解

    在网上找了N多相关的东西总说的不够细,现在终于找到了.可以了解web.cofig和Global.asax之间的关系以及执行的顺序. 在Global.asax.cs文件中 protected void ...

  6. ADO.net笔记

    1.DbConnectionConnection对象也称为数据库连接对象,Connection对象的功能是负责对数据源的连接.所有Connection对象的基类都是DbConnection类.Conn ...

  7. NSMutableString和NSString区别,及相互转换方法

    NSString是一个不可变的字符串对象.这不是表示这个对象声明的变量的值不可变,而是表示它初始化以后,你不能改变该变量所分配的内存中的值,但你可以重新分配该变量所处的内存空间.而NSMutableS ...

  8. LeetCode第[78]题(Java):Subsets(求子集)扩展——第[90]题:Subsets 2

    题目:矩阵置0 难度:Easy 题目内容:   Given a set of distinct integers, nums, return all possible subsets (the pow ...

  9. sql数据类型转换函数

    1.CAST()CAST (<expression> AS <data_ type>[ length ]) 2.CONVERT()CONVERT (<data_ type ...

  10. Mercurial的使用心得

    本文发表地址:http://www.xiabingbao.com/mercurial/2015/01/22/mercurial-understanding/ 本人接触版本控制的历史 在很久很久以前,我 ...