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)的更多相关文章

  1. Codeforces Beta Round #73 (Div. 2 Only)

    Codeforces Beta Round #73 (Div. 2 Only) http://codeforces.com/contest/88 A 模拟 #include<bits/stdc+ ...

  2. Codeforces Beta Round #94 div2 D 优先队列

    B. String time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...

  3. Codeforces Beta Round #107(Div2)

    B.Phone Numbers 思路:就是简单的结构体排序,只是这里有一个技巧,就是结构体存储的时候,直接存各种类型的电话的数量是多少就行,在读入电话的时候,既然号码是一定的,那么就直接按照格式%c读 ...

  4. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  5. 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]中有多少个数 ...

  6. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  7. Codeforces Beta Round #13 C. Sequence (DP)

    题目大意 给一个数列,长度不超过 5000,每次可以将其中的一个数加 1 或者减 1,问,最少需要多少次操作,才能使得这个数列单调不降 数列中每个数为 -109-109 中的一个数 做法分析 先这样考 ...

  8. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  9. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

随机推荐

  1. 利用flex解决input定位的问题

    用简单的布局搞定input框使用fixed下输入的问题 最近在做移动端H5聊天应用发现,当input框在最底部并且使用 position:fixed 属性的时候在苹果手机中会出现不兼容的情况 ​

  2. 对用pyinstaller打包的exe程序进行反编译,获得源码

    参考文章: 1.https://www.cnblogs.com/DirWang/p/12018949.html#PyInstallerExtractor 2.https://msd.misuland. ...

  3. ACNet:用于图像超分的非对称卷积网络

    编辑:Happy 首发:AIWalker Paper:https://arxiv.org/abs/2103.13634 Code:https://github.com/hellloxiaotian/A ...

  4. Redis-AOF日志与RDB快照

    AOF日志与RDB是Reids中两大持久化机制,当服务器或者Reids宕机的时候可以通过这两大机制恢复Redis的数据. 先说说AOF日志吧,在执行一条操作请求时,Redis先将命令在内存中执行,之后 ...

  5. 【解决】Could not GET 'https://maven.google.com

    现象 解决方案 1. 由于Google被墙导致的问题 参考 配置阿里云源修改maven的源地址. 2. 由于错误配置代理导致的问题(提示400) 查看工程目录下的gradle.properties和C ...

  6. 开篇:ISP基本模块介绍

    一般来说,ISP pipeline没有非常严格的流程,各家厂商具体实现方案或多或少都有些差异,但大致流程如下图所示.其中,又可以根据处理的数据将其分成BPS(Bayer process segment ...

  7. 2020 OO 第一单元总结 表达式求导

    title: BUAA-OO 第一单元总结 date: 2020-03-19 20:53:41 tags: OO categories: 学习 OO第一单元通过三次递进式的作业让我们实现表达式求导,在 ...

  8. 【接入指南】一个Demo带你玩转华为帐号服务

    在<接入指南:一文带你了解华为帐号服务>中已经给大家介绍了华为帐号服务有哪些优势,如一键授权登录华为全场景共享.共享华为帐号所有用户资源.帐号安全可靠.接入方便快捷等,以及为什么能帮助开发 ...

  9. CMD控制台(命令提示符)的打开方式

    打开CMD的方式 打开+系统+命令提示符 Win键 +R 输入cmd 打开控制台(推荐使用) 在任意的文件夹下面,按住shift键+鼠标右键点击+在此处打开命令行窗口 资源管理器的地址栏前面加上cmd ...

  10. 06_pytorch的autograd操作

    06_pytorch的autograd操作 目录 一.引言 二.Variable 2.1 Variable 的数据结构 2.2 反向传播 2.3 autograd 求导数和手动求导数 三.计算图 3. ...