Codeforces Beta Round #97 (Div. 2)
A题求给出映射的反射,水题
#include <cstdio>
int x,ans[105],n;
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&x);
ans[x]=i;
}for(int i=1;i<=n;i++)printf("%d ",ans[i]);
return 0;
}
B题,三进制的减法
#include <cstdio>
#include <algorithm>
using namespace std;
int a[1000],b[1000],c[1000];
int A,B,C,la,lb,lc;
int main(){
scanf("%d%d",&A,&C);
while(A){a[la++]=A%3;A/=3;}
while(C){c[lc++]=C%3;C/=3;}
for(int i=0;i<la||i<lc;i++){
if(a[i]==c[i])b[i]=0;
if((a[i]+1)%3==c[i])b[i]=1;
if((a[i]+2)%3==c[i])b[i]=2;
}for(int i=max(la,lc);i>=0;i--)B=B*3+b[i];
printf("%d\n",B);
return 0;
}
C题题意,更改一个数字,使得数列总和最小
#include <cstdio>
#include <algorithm>
using namespace std;
int n,a[100005];
int main(){
scanf("%d",&n);
for(int i=0;i<n;i++)scanf("%d",&a[i]);
sort(a,a+n);
if(a[n-1]==1)a[n-1]=2;else a[n-1]=1;
sort(a,a+n);
for(int i=0;i<n;i++)printf("%d ",a[i]);
return 0;
}
D题给出八个点,判断是否能够分成两组,使得第一组四点构成正方形,第二组四点构成矩形
构成矩形的判断方式是,对角线长度相等,并且中点重合,构成正方形的判断方式是已构成的矩形相邻两边长度相等
对于八个点利用状态压缩枚举每一种四个点的选择情况,判断是否满足条件即可
#include <cstdio>
#include <algorithm>
using namespace std;
struct data{double x,y;}p[8],p1[4],p2[4];
bool cmp(data a,data b){return a.x==b.x?a.y<b.y:a.x<b.x;}
bool CheckSquare(){
sort(p1,p1+4,cmp);
double d1=(p1[3].x-p1[0].x)*(p1[3].x-p1[0].x)+(p1[3].y-p1[0].y)*(p1[3].y-p1[0].y);
double d2=(p1[2].x-p1[1].x)*(p1[2].x-p1[1].x)+(p1[2].y-p1[1].y)*(p1[2].y-p1[1].y);
return(d1==d2&&(p1[3].x+p1[0].x==p1[1].x+p1[2].x)&&(p1[3].y+p1[0].y==p1[1].y+p1[2].y));
}
bool CheckRectangle(){
sort(p2,p2+4,cmp);
double d1=(p2[3].x-p2[0].x)*(p2[3].x-p2[0].x)+(p2[3].y-p2[0].y)*(p2[3].y-p2[0].y);
double d2=(p2[2].x-p2[1].x)*(p2[2].x-p2[1].x)+(p2[2].y-p2[1].y)*(p2[2].y-p2[1].y);
double d3=(p2[2].x-p2[0].x)*(p2[2].x-p2[0].x)+(p2[2].y-p2[0].y)*(p2[2].y-p2[0].y);
double d4=(p2[0].x-p2[1].x)*(p2[0].x-p2[1].x)+(p2[0].y-p2[1].y)*(p2[0].y-p2[1].y);
return(d1==d2&&d3==d4&&(p2[3].x+p2[0].x==p2[1].x+p2[2].x)&&(p2[3].y+p2[0].y==p2[1].y+p2[2].y));
}
int main(){
for(int i=0;i<8;i++)scanf("%lf%lf",&p[i].x,&p[i].y);
for(int i=0;i<256;i++){
int tmp=i,cnt=0;
for(int j=0;j<8;j++)if((1<<j)&i)cnt++;
if(cnt!=4)continue; cnt=0;int cnt0=0;
for(int j=0;j<8;j++){
if((1<<j)&i)p1[cnt++]=p[j];
else p2[cnt0++]=p[j];
}
if(CheckSquare()&&CheckRectangle()){
puts("YES");
for(int j=0;j<8;j++)if(!((1<<j)&i))printf("%d ",j+1);puts("");
for(int j=0;j<8;j++)if(((1<<j)&i))printf("%d ",j+1);puts("");
return 0;
}
}puts("NO");
return 0;
}
E题的意思是有两个人,分别轮流去除字符串中的一个字符,一个为了让字符串变小,一个为了让字符串变大,问最后的结果的可能性
分类讨论题:
#include<bits/stdc++.h>
using namespace std;
int flag[4],x,y,z,len;
char s[100005];
bool check01(){
if(s[len-1]=='0')return 0;
x=1,y=0,z=0;
for(int i=0;i<len-1;i++){
if(s[i]=='1')x++;
if(s[i]=='0')y++;
if(s[i]=='?')z++;
}if(x-(z+y)>=2||y-(x+z)>=1)return 0;
return 1;
}
bool check10(){
if(s[len-1]=='1')return 0;
x=0,y=1,z=0;
for(int i=0;i<len-1;i++){
if(s[i]=='1')x++;
if(s[i]=='0')y++;
if(s[i]=='?')z++;
}if(x-(z+y)>=2||y-(x+z)>=1)return 0;
return 1;
}
int main(){
scanf("%s",s);
len=strlen(s);
for(int i=0;i<len;i++){
if(s[i]=='1')x++;
if(s[i]=='0')y++;
if(s[i]=='?')z++;
}if(x+z-y>=2)flag[0]=1;
if(y+z-x>=1)flag[1]=1;
if(check01())flag[2]=1;
if(check10())flag[3]=1;
if(flag[1])printf("00\n");
if(flag[2])printf("01\n");
if(flag[3])printf("10\n");
if(flag[0])printf("11\n");
return 0;
}
Codeforces Beta Round #97 (Div. 2)的更多相关文章
- Codeforces Beta Round #97 (Div. 1) C. Zero-One 数学
C. Zero-One 题目连接: http://codeforces.com/contest/135/problem/C Description Little Petya very much lik ...
- Codeforces Beta Round #97 (Div. 1) B. Rectangle and Square 暴力
B. Rectangle and Square 题目连接: http://codeforces.com/contest/135/problem/B Description Little Petya v ...
- Codeforces Beta Round #97 (Div. 1) A. Replacement 水题
A. Replacement 题目连接: http://codeforces.com/contest/135/problem/A Description Little Petya very much ...
- Codeforces Beta Round #97 (Div. 1)
B 判矩阵的时候 出了点错 根据点积判垂直 叉积判平行 面积不能为0 #include <iostream> #include<cstdio> #include<cstr ...
- Codeforces Beta Round #80 (Div. 2 Only)【ABCD】
Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...
- Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】
Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...
- Codeforces Beta Round #79 (Div. 2 Only)
Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...
- Codeforces Beta Round #77 (Div. 2 Only)
Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...
- Codeforces Beta Round #76 (Div. 2 Only)
Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...
随机推荐
- JS输出日历
页面HTML代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> &l ...
- boa,thttp服务器安装,配置,测试
boa 1, SERVER_ROOT自定义,define.h头文件中,默认“/etc/boa" 2,./configure 3,修改CC,默认CC=gcc,make 4,error util ...
- 解密电子书之二:EPD控制芯片
EPD控制芯片大致上相当于计算机的显卡,没了它,所有电子书都变白板.类似显卡中的ATI与NVIDIA,EPD控制芯片中也是两家:Surf(泰信科)和EPSON(爱普生),其中爱普生是最早推出电子纸显示 ...
- android 用 XML 自定义边框(只上下边框有色)
直接上代码: <?xml version="1.0" encoding="UTF-8"?> <layer-list xmlns:android ...
- poj2136---输出特殊图形
#include <stdio.h> #include <stdlib.h> #include<string.h> ]; int find(int pos,int ...
- c++游戏编程书籍
如果要自学游戏程序开发的话,可以看看下面的,呵呵. 游戏开发资料(PDF书都是中文版的,非英文,很多是本人自己扫描制作,从未网上发布过,所以独家啦): 1.Gamebryo 2.2游戏引擎(盛大.腾 ...
- python 类型转换函数
python提供了一些可将某个值从一种类型转换为另一种类型的内置函数. 1. int函数可以把任何可以转换为整型的值转换为整型.int可以将浮点数转换为整数,但不会做四舍五入操作,而是直接丢弃小数部分 ...
- Cocos2d—X游戏开发之CCTableView详解(十一)
本来很早就想写关于CCTableView的文章,但是在基本功能实现之后呢,项目需求增加导致对这个控件的研究必须更加深入一点. 好的,现在开始介绍一下这个控件,在Cocos2d—X引擎中,这是一个仿制i ...
- 君子性非异也,善假于物也 - Threejs 引入TrackballControls 查看场景
君子性非异也,善假于物也 - Threejs 引入TrackballControls 查看场景 太阳火神的漂亮人生 (http://blog.csdn.net/opengl_es) 本文遵循" ...
- eclipse 中修改 M2_REPO的值
转自: http://blog.csdn.net/xuechongyang/article/details/8267440 从eclipse中增加了maven2的插件之后,maven默认的本地库的路径 ...