2016ACM青岛区域赛题解
A、Relic Discovery_hdu5982
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 57 Accepted Submission(s): 49
2
1 2
3 4
#include <iostream>
#include <cstdio> using namespace std; int main()
{
int n;
int t;
int a,b;
scanf("%d",&t);
for(int i=;i<t;i++){
scanf("%d",&n);
int sum=;
for(int j=;j<n;j++){
scanf("%d %d",&a,&b);
sum+=a*b;
}
printf("%d\n",sum);
} return ;
}
B、Pocket Cube_5983
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 23 Accepted Submission(s): 9
The cube consists of 8 pieces, all corners.
Each piece is labeled by a three dimensional coordinate (h, k, l) where h, k, l ∈ {0, 1}. Each of the six faces owns four small faces filled with a positive integer.
For each step, you can choose a certain face and turn the face ninety degrees clockwise or counterclockwise.
You should judge that if one can restore the pocket cube in one step. We say a pocket cube has been restored if each face owns four same integers.
For each test case, the first line describes the top face of the pocket cube, which is the common 2 × 2 face of pieces
labelled by (0, 0, 1),(0, 1, 1),(1, 0, 1),(1, 1, 1). Four integers are given corresponding to the above pieces.
The second line describes the front face, the common face of (1, 0, 1),(1, 1, 1),(1, 0, 0),(1, 1, 0). Four integers are
given corresponding to the above pieces.
The third line describes the bottom face, the common face of (1, 0, 0),(1, 1, 0),(0, 0, 0),(0, 1, 0). Four integers are
given corresponding to the above pieces.
The fourth line describes the back face, the common face of (0, 0, 0),(0, 1, 0),(0, 0, 1),(0, 1, 1). Four integers are
given corresponding to the above pieces.
The fifth line describes the left face, the common face of (0, 0, 0),(0, 0, 1),(1, 0, 0),(1, 0, 1). Four integers are given
corresponding to the above pieces.
The six line describes the right face, the common face of (0, 1, 1),(0, 1, 0),(1, 1, 1),(1, 1, 0). Four integers are given
corresponding to the above pieces.
In other words, each test case contains 24 integers a, b, c to x. You can flat the surface to get the surface development
as follows.
+ - + - + - + - + - + - +
| q | r | a | b | u | v |
+ - + - + - + - + - + - +
| s | t | c | d | w | x |
+ - + - + - + - + - + - +
| e | f |
+ - + - +
| g | h |
+ - + - +
| i | j |
+ - + - +
| k | l |
+ - + - +
| m | n |
+ - + - +
| o | p |
+ - + - +
#include <iostream>
#include <cstdio> using namespace std; int a[][];
int b[][]; bool judge(){
int i=;
for(int j=;j<=;j++){
if(a[j][]==a[j][]&&a[j][]==a[j][]&&a[j][]==a[j][]){
i++;
}
}
if(i==){
return true;
}else{
return false;
}
} void opera1(){//前面顺时针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t2;
a[][]=t1;
}
void opera2(){//前面逆时针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t2;
a[][]=t1;
}
void opera3(){//上面顺时针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t1;
a[][]=t2;
}
void opera4(){//上面逆时针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t2;
a[][]=t1;
}
void opera5(){//左边顺指针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t1;
a[][]=t2;
}
void opera6(){//左边逆时针
int t1,t2;
t1=a[][];
t2=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=a[][];
a[][]=a[][]; a[][]=t1;
a[][]=t2;
}
int main()
{
int n;
scanf("%d",&n);
while(n--){
for(int i=;i<=;i++){
for(int j=;j<=;j++){
scanf("%d",&a[i][j]);
b[i][j]=a[i][j];
}
}
if(judge()){
printf("YES\n");
continue;
}
opera1();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
opera2();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
opera3();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
opera4();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
opera5();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
opera6();
if(judge()){
printf("YES\n");
continue;
}
for(int i=;i<=;i++){
for(int j=;j<=;j++){
a[i][j]=b[i][j];
}
}
printf("NO\n");
}
return ;
}
C、Pocky_hdu5984
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 54 Accepted Submission(s): 20
While the length of remaining pocky is longer than d, we perform the following procedure. We break the pocky at any point on it in an equal possibility and this will divide the remaining pocky into two parts. Take the left part and eat it. When it is not longer than d, we do not repeat this procedure.
Now we want to know the expected number of times we should repeat the procedure above. Round it to 6 decimal places behind the decimal point.
1.0 1.0
2.0 1.0
4.0 1.0
8.0 1.0
16.0 1.0
7.00 3.00
1.693147
2.386294
3.079442
3.772589
1.847298
#include <iostream>
#include <cstdio>
#include <cmath> using namespace std; int main()
{
int n;
double a,b;
scanf("%d",&n);
while(n--){
scanf("%lf%lf",&a,&b);
if(a<=b){
printf("0.000000\n");
continue;
}
printf("%.6lf\n",log(a)-log(b)+);
}
return ;
}
2016ACM青岛区域赛题解的更多相关文章
- 2016 ACM/ICPC Asia Regional Qingdao Online(2016ACM青岛网络赛部分题解)
2016 ACM/ICPC Asia Regional Qingdao Online(部分题解) 5878---I Count Two Three http://acm.hdu.edu.cn/show ...
- 2016青岛区域赛.Coding Contest(费用流 + 概率计算转换为加法计算)
Coding Contest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- ACM/ICPC2016 青岛区域赛
A(hdu5982).(模拟) 题意:输入n对数,将每对数相乘并相加 分析:模拟 B(hdu5983).(模拟) 题意:给你一个二阶魔方,问能否通过一次旋转使得给定魔方的每个面颜色相同 分析:模拟 C ...
- 2016ACM-ICPC Qingdao Online青岛网络赛题解
TonyFang+Sps+我=5/12 滚了个大粗 2016年9月21日16:42:36 10题完工辣 01 题意:求形同的数中大于n的最小值 题解:预处理所有的(5194个),在这里面二分 #inc ...
- 2016 年 ACM/ICPC 青岛区域赛 Problem C Pocky
昨晚乱入学弟的训练赛,想了一下这个题.推导的过程中,加深了对公理化的概率论理解.$\newcommand{\d}{\mathop{}\!\mathrm{d}}$ 解法一 考虑 $ d < L$ ...
- 2018 ACM-ICPC南京区域赛题解
解题过程 开场开A,A题shl看错题意,被制止.然后开始手推A,此时byf看错E题题意,开始上机.推出A的规律后,shl看了E题,发现题意读错.写完A题,忘记判断N=0的情况,WA+1.过了A后,sh ...
- Tournament ZOJ - 4063 (青岛区域赛 F 打表)
打表题.. 规律是找出来了 奈何优化不了 .... #include <iostream> #include <cstdio> #include <sstream> ...
- UVALive - 7740 Coding Contest 2016 青岛区域赛 (费用流)
题意:每个点i有\(s_i\)个人和\(b_i\)份食物,每个人都要找到一份食物.现在有M条有向边,从点i到点j,容量为c,第一次走过不要紧,从第二次开始就要承担\(p(0<p<1)\)的 ...
- 第42届亚洲区域赛青岛站(2017icpc青岛)经验总结以及一些感想
上一次写这种东西还是天梯赛,当时打完心里也是挺激动的,然后我们队也没有去参加省赛,但是过了一段时间我还是从那里面恢复了出来.因为我当时确实还是很菜的,当时连个暴力都不会,看着自己仅过的那些百度的题目确 ...
随机推荐
- perl
introduction: http://www.yiibai.com/perl/perl_introduction.html functions: http://www.yiibai.com/per ...
- C#面向对象设计模式纵横谈——6.Prototype 原型模式(创建型模式)
动机(Motivation) 在软件系统中,经常面临着“某些结构复杂的对象”的创建工作.由于需求的变化,这些对象经常面临着剧烈的变化,但他们却拥有比较稳定一致的接口. 如何应对这种变化?如何向“客户程 ...
- HiShop2.x版本中的上传插件分析,得出所用的模板语言为Underscore.js 1.6.0且自己已修改
效果: 上传组件非常的酷,但是分析其使用JS写法使用了模板语言的,代码如下: <script type="text/j-template" id="tpl_popb ...
- mybatis源码分析:
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #e4af0a } p. ...
- Linux 基础
命令说明 $ type cmd # 获取命令类型 $ which cmd # 命令的位置 $ help cmd / cmd --help / man cmd # 获取命令帮助 $ whatis cmd ...
- Fixing DSDT
https://clover-wiki.zetam.org/Fixing-DSDT#dsdt-mask_fixdisplay_0100-bit-8
- php实现文件上传与下载(中)
出现不想让用户看见的信息,可以使用错误抑制符号@:当然能echo的东西都是可以赋值给一个变量的: 定义用户上传文件类型,将其放在数组变量allowExt中,用if(!in_array(第一个参数为获取 ...
- vim vi Ubuntu
在vi编辑模式下按退格键不能删除内容,按方向键不能上下左右移动?如果是则:1. 在vi里非编辑模式下按冒号进入到末行命令模式,然后输入set nocompatible,回车,然后在进入vi编辑模式,看 ...
- Demo 版
Demo1 美食网站 Demo2 12301智慧旅游公共服务平台 Demo3 react_and_koa example
- [译]How to Write a Git Commit Message
原文: http://chris.beams.io/posts/git-commit/ 介绍:为什么好的commit message很重要 你浏览项目commit message的时候或多或少会有些困 ...