Codeforces Beta Round #73(Div2)
A - Chord
题意:就是环中有12个字符,给你三个字符,判断他们之间的间隔,如果第一个和第二个间隔是3并且第二个和第三个间隔是4,那么就输出minor,如果第一个和第二个间隔是4并且第二个和第三个间隔是3,那么就输出major,否则输出strange
思路:用一个数组a中相对位置存入1,因为1个循环是12,让你判断的总长度是7,所以不会产生干扰,直接进行a[i]、a[i+3]、a[i+7]判断即可
代码:

1 #include<iostream>
2 #include<algorithm>
3 #include<cmath>
4 #include<cstdio>
5 #include<cstring>
6 using namespace std;
7 int main(){
8 //C, C#, D, D#, E, F, F#, G, G#, A, B,H
9 string s[28]={"0","C","C#","D","D#","E","F","F#","G","G#","A","B","H"};
10 string s1;
11 string s2;
12 string s3;
13 cin>>s1;
14 cin>>s2;
15 cin>>s3;
16 int flag=0;
17 int flag1=0,flag2=0,flag3=0;
18 for(int i=1;i<=12;i++){
19 if(s1==s[i]){
20 flag1=i;
21 }
22 if(s2==s[i]){
23 flag2=i;
24 }
25 if(s3==s[i]){
26 flag3=i;
27 }
28 }
29 int a[50]={0};
30 a[flag1]=1;
31 a[flag2]=1;
32 a[flag3]=1;
33 a[flag1+12]=2;
34 a[flag2+12]=2;
35 a[flag3+12]=2;
36 for(int i=0;i<30;i++){
37 if(a[i]!=0&&a[i+3]!=0&&a[i+7]!=0){
38 flag=1;
39 break;
40 }
41 if(a[i]!=0&&a[i+4]!=0&&a[i+7]!=0){
42 flag=2;
43 break;
44 }
45 }
46 if(flag==1){
47 printf("minor");
48 }else if(flag==2){
49 printf("major");
50 }else{
51 printf("strange");
52 }
53 }
B - Keyboard
题意:题目中给定一种特殊的矩阵键盘,S是可以让小写字母变成大写字母,如果S和给定字母的小写字母在一定范围内,则用一个手输出,否则用两只手输出,问至少多少次用两只手输出
思路:一开始想着就是直接存,然后先找到距离内的字符做好标记,直接看看给定的字符串中有多少个在这个未标记的范围内,结果这样是错的,其实未标记的字母可能也存在于已标记的范围中,所以应该以已标记的为主要对比对象
代码:

1 #include<iostream>
2 #include<algorithm>
3 #include<cmath>
4 #include<cstdio>
5 #include<cstring>
6 using namespace std;
7 int main(){
8 int n,m,x,d;
9 scanf("%d %d %d",&n,&m,&d);
10 char s[60][60];
11 int xx[4000][2];
12 int flag=0;
13 getchar();//存入
14 for(int i=0;i<n;i++){
15 for(int j=0;j<m;j++){
16 scanf("%c",&s[i][j]);
17 if(s[i][j]=='S'){
18 xx[flag][0]=i;
19 xx[flag][1]=j;
20 flag++;
21 }
22 }
23 getchar();
24 }
25 int t;
26 int ss[60][60];
27 for(int i=0;i<60;i++){
28 for(int j=0;j<60;j++){
29 ss[i][j]=0;
30 }
31 }
32 scanf("%d",&t);
33 string tt;
34 getchar();
35 getline(cin,tt);
36 for(int i=0;i<flag;i++){
37 int x,y;
38 x=xx[i][0];
39 y=xx[i][1];
40 ss[x][y]=1;
41 for(int ii=0;ii<n;ii++){
42 for(int j=0;j<m;j++){
43 long int st=0;
44 st=(ii-x)*(ii-x)+(j-y)*(j-y);
45 if(st<=d*d){
46 ss[ii][j]=1;
47 }
48 }
49
50 }
51 }
52 int p=0;
53 if(flag==0){
54 p=1;
55 }//标记这是没有shift键的
56 int sum=0;
57 int flag1=0;
58 int ds=0;
59 for(int i=0;i<t;i++){
60 int flagg=0;
61 if(tt[i]>='A'&&tt[i]<='Z'){
62 ds++;
63 int ff=0,f=0;
64 for(int ii=0;ii<n;ii++){
65 f=0;
66 for(int jj=0;jj<m;jj++){
67 if(tt[i]-'A'+'a'==s[ii][jj]&&ss[ii][jj]==1){
68 f=1;
69 break;
70 }
71 if(tt[i]-'A'+'a'==s[ii][jj]&&ss[ii][jj]==0){
72 ff=1;
73 }
74 if(tt[i]-'A'+'a'==s[ii][jj]){
75 flagg++;
76 }
77 }
78 if(f==1){
79 break;
80 }
81 }
82 if(f==1){
83 continue;
84 }else if(ff==1){
85 sum++;
86 }
87 if(flagg==0){
88 flag1=1;
89 }
90 }else{
91 for(int ii=0;ii<n;ii++){
92 for(int jj=0;jj<m;jj++){
93 if(tt[i]==s[ii][jj]){
94 flagg++;
95 }
96 }
97 }
98 if(flagg==0){
99 flag1=1;
100 }
101 }
102 }
103 if((flag1==1)||(ds>0&&p==1)){
104 printf("-1\n");
105 }else{
106 printf("%d\n",sum);
107 }
108
109 }
C - Trains
题意:其实就是问,在两个数的最小公倍数内,谁的商更大一些,但是最小公倍数的最后一次要给除数大的那边,也就是说除数小的那个数的商要减1,然后比较大小分别输出相应的内容
思路:直接找最小公倍数以及商就好了
代码:

1 #include<iostream>
2 #include<algorithm>
3 #include<cmath>
4 #include<cstdio>
5 #include<cstring>
6 using namespace std;
7 long long int cm(long long int a,long long int b){
8 if(a==b){
9 return a;
10 }
11 if(a>b){
12 a-=b;
13 cm(a,b);
14 }else{
15 b-=a;
16 cm(a,b);
17 }
18 }
19 int main(){
20 long long int a,b,c;
21 scanf("%lld %lld",&a,&b);
22 c=(a*b)/(cm(a,b));
23 long long int num1=c/a,num2=c/b;
24 if(a>b){
25 num2-=1;
26 }
27 if(b>a){
28 num1-=1;
29 }
30 if(num1>num2){
31 printf("Dasha");
32 }else if(num1<num2){
33 printf("Masha");
34 }else{
35 printf("Equal");
36 }
37
38 }
Codeforces Beta Round #73(Div2)的更多相关文章
- Codeforces Beta Round #73 (Div. 2 Only)
Codeforces Beta Round #73 (Div. 2 Only) http://codeforces.com/contest/88 A 模拟 #include<bits/stdc+ ...
- Codeforces Beta Round #94 div2 D 优先队列
B. String time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- Codeforces Beta Round #107(Div2)
B.Phone Numbers 思路:就是简单的结构体排序,只是这里有一个技巧,就是结构体存储的时候,直接存各种类型的电话的数量是多少就行,在读入电话的时候,既然号码是一定的,那么就直接按照格式%c读 ...
- 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 #62 题解【ABCD】
Codeforces Beta Round #62 A Irrational problem 题意 f(x) = x mod p1 mod p2 mod p3 mod p4 问你[a,b]中有多少个数 ...
- 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 #13 C. Sequence (DP)
题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...
- 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 ...
随机推荐
- net start MongoDB 服务没有响应控制功能。 请键入 NET HELPMSG 2186 以获得更多的帮助。
我在 Windows 电脑上修改了 mongo.cfg 文件后 执行 net start mongodb 的时候,命令行出现了这个报错. 这个报错,有几种情况可以进行排查 1. 你的 mongod 命 ...
- c/s应用程序自动更新组件GeneralUpdate3.2.1发布
一.组件简介 GeneralUpdate是基于.net standard 开发的一款(c/s应用)自动升级程序.该组件将更新的核心部分抽离出来方便应用于多种项目当中目前适用于wpf,控制台应用,win ...
- odoo 安装配置
Linux ubuntu 环境 1.建个python虚环境 也可用其他替代 virtualenv env 2.找个稳定版本下载 wget https://nightly.odoo.com/8.0/ni ...
- 第14 章 : Kubernetes Service讲解
Kubernetes Service 本文将主要分享以下四方面的内容: 为什么需要 K8s service: K8s service 用例解读: K8s service 操作演示: K8s servi ...
- CyclicBarrier:人齐了,老司机就可以发车了!
上一篇咱讲了 CountDownLatch 可以解决多个线程同步的问题,相比于 join 来说它的应用范围更广,不仅可以应用在线程上,还可以应用在线程池上.然而 CountDownLatch 却是一次 ...
- openGL常见函数意义
最近在课程上在学习计算机图像,对于突然冒出来的好多glut库里的函数感觉很难招架.把示例代码一行行百度下来,总算是差不多理解了大概的意思,在这里分享一下绘制图像需要的基础的函数. 1. 配置环境 对于 ...
- 如何使用yolov3训练自己的数据集
博客主要结构 1. 如何在ubuntu18.04上安装yolo 2 .如何配置yolov3 3 .如何制作自己的训练集测试集 4 .如何在自己的数据集上运行yolov3 1. 在ubuntu18.04 ...
- Java(25-40)【数据类型转换、运算符、方法入门】
1.ASCII编码表 0--48 A--65 a--97 2. Unicode万国码 字符'中'为20013 3.算数运算符 double类型的加上int类型结果为double byte short ...
- 1.jsp-out和response输出的区别
jsp中代码: out.write("out输出1 <br/>"); out.write("out输出2 <br/>"); respon ...
- 9. resultMap 结果映射集
@Data public class CreditCard extends BankCard { /** * 消费额度 */ private String creditLine; } @Data pu ...