1.
十进制整数 2 在十进制中是 1 位数,在二进制中对应 10 ,是 2 位数。
十进制整数 22 在十进制中是 2 位数,在二进制中对应 10110 ,是 5 位数。
请问十进制整数 2022 在二进制中是几位数?
#include<stdio.h> int main() { int n=0; int sum=0; scanf("%d",&n); while(n) { n=n/2; sum++; } printf("%d",sum); return 0; }
2.
小蓝特别喜欢调和级数 S(n)=1/1+1/2+1/3+1/4+...+1/n 。
请问,n 至少为多大时,S(n)>12 ?
#include<stdio.h> int main() { double sum=0; int n=0; int i=0; for(i=1;sum<=12;i++) { sum+=1.0/i; } printf("%d",i-1); //91380 //注意输出时要i-1,因为此时的i是sum大于12的情况 return 0; }
3.
给定一个字母矩阵,如果矩阵中的某个位置不在四条边上,而且该位置上的字母小于其上下左右四个位置的字母,则称为一个山谷。想给你一个矩阵,算算有多少个这样的山谷
例如,对于如下矩阵
输入:3 5 DDDDD CADCE FFFFA 输出:2 输入: 30 60 PHQGHUMEAYLNLFDXFIRCVSCXGGBWKFNQDUXWFNFOZVSRTKJPREPGGXRPNRVY STMWCYSYYCQPEVIKEFFMZNIMKKASVWSRENZKYCXFXTLSGYPSFADPOOEFXZBC OEJUVPVABOYGPOEYLFPBNPLJVRVIPYAMYEHWQNQRQPMXUJJLOOVAOWUXWHMS NCBXCOKSFZKVATXDKNLYJYHFIXJSWNKKUFNUXXZRZBMNMGQOOKETLYHNKOAU GZQRCDDIUTEIOJWAYYZPVSCMPSAJLFVGUBFAAOVLZYLNTRKDCPWSRTESJWHD IZCOBZCNFWLQIJTVDWVXHRCBLDVGYLWGBUSBMBORXTLHCSMPXOHGMGNKEUFD XOTOGBGXPEYANFETCUKEPZSHKLJUGGGEKJDQZJENPEVQGXIEPJSRDZJAZUJL LCHHBFQMKIMWZOBIWYBXDUUNFSKSRSRTEKMQDCYZJEEUHMSRQCOZIJIPFION EEDDPSZRNAVYMMTATBDZQSOEMUVNPPPSUACBAZUXMHECTHLEGRPUNKDMBPPW EQTGJOPARMOWZDQYOXYTJBBHAWDYDCPRJBXPHOOHPKWQYUHRQZHNBNFUVQNQ QLRZJPXIOGVLIEXDZUZOSRKRUSVOJBRZMWZPOWKJILEFRAAMDIGPNPUUHGXP QNJWJMWAXXMNSNHHLQQRZUDLTFZOTCJTNZXUGLSDSMZCNOCKVFAJFRMXOTHO WKBJZWUCWLJFRIMPMYHCHZRIWKBARXBGFCBCEYHJUGIXWTBVTREHBBCPXIFB XVFBCGKCFQCKCOTZGKUBMJRMBSZTSSHFROEFWSJRXJHGUZYUPZWWEIQURPIX IQFLDUUVEOOWQCUDHNEFNJHAIMUCZFSKUIDUBURISWTBRECUYKABFCVKDZEZ TOIDUKUHJZEFCZZZBFKQDPQZIKFOBUCDHTHXDJGKJELRLPAXAMCEROSWITDP TPCCLIFKELJYTIHRCQAYBNEFXNXVGZEDYYHNGYCDRUDMPHMECKOTRWOSPOFG HFOZQVLQFXWWKMFXDYYGMDCASZSGOVSODKJGHCWMBMXRMHUYFYQGAJQKCKLZ NAYXQKQOYZWMYUBZAZCPKHKTKYDZIVCUYPURFMBISGEKYRGZVXDHPOAMVAFY RARXSVKHTQDIHERSIGBHZJZUJXMMYSPNARAEWKEGJCCVHHRJVBJTSQDJOOTG PKNFPFYCGFIEOWQRWWWPZSQMETOGEPSPXNVJIUPALYYNMKMNUVKLHSECDWRA CGFMZKGIPDFODKJMJQWIQPUOQHIMVFVUZWYVIJGFULLKJDUHSJAFBTLKMFQR MYJFJNHHSSQCTYDTEAMDCJBPRHTNEGYIWXGCJWLGRSMEAEARWTVJSJBAOIOJ LWHYPNVRUIHOSWKIFYGTYDHACWYHSGEWZMTGONZLTJHGAUHNIHREQGJFWKJS MTPJHAEFQZAAULDRCHJCCDYRFVVRIVUYEEGFIVDRCYGURQDREDAKUBNFGUPR OQYLOBCWQXKZMAUSJGMHCMHGDNMPHNQKAMHURKTRFFACLVGRZKKLDACLLTEO JOMONXRQYJZGINRNNZWACXXAEDRWUDXZRFUSEWJTBOXVYNFHKSTCENAUMNDD XFDMVZCAUTDCCKXAAYDZSXTTOBBGQNGVVPJGOJOGLMKXGBFCPYPCKQCHBDDZ WRXBZMQRLXVOBTWHXGINFGFRCCLMZNMJUGWWBSQFCIHUBSJOLLMSQSGHMCPH 输出: 267
#include<stdio.h> int main() { int n,m; int arr[100][100]={0}; int sum=0; scanf("%d %d",&n,&m); for(int i=0;i<n;i++) { for(int j=0;j<m;j++) { scanf(" %c",&arr[i][j]); } } for(int i=1;i<n-1;i++) { for(int j=1;j<m-1;j++) { if(arr[i][j]<arr[i+1][j]&&arr[i][j]<arr[i-1][j]&&arr[i][j]<arr[i][j+1]&&arr[i][j]<arr[i][j-1]) { sum++; } } } printf("\n%d",sum); return 0; }
4.
问题描述
输入一个由小写英文字母组成的字符串,请将其中的元音字母(a, e, i, o, u)转换成大写,其它字母仍然保持小写。
输入格式
输入一行包含一个字符串。
输出格式
输出转换后的字符串。
样例输入
lanqiao
样例输出
lAnqIAO
#include<stdio.h> int main() { char ch[100]={0}; int i=0; gets(ch); while(ch[i]!='0') { if(ch[i]=='a'||ch[i]=='o'||ch[i]=='e'||ch[i]=='i'||ch[i]=='u')//(a, e, i, o, u) { ch[i]-=32; } i++; } puts(ch); return 0; }
5.
问题描述
小蓝有一个充电器,可以使用不同的电压和电流充电。
给定充电器工作的记录,请计算在这个记录期间总共通过充电传输了多少电能。
输入格式
输入第一行包含一个整数 n , 表示记录的条数。
接下来 n 行,每行包含一个时刻 T 和两个非负整数 U, I,表示在时刻 T 充电电压变为 U(单位伏),电流变为 I(单位A)。
最后一行满足 U 和 I 均为 0,在前面的行中也可能出现 U、I 为 0 的情况。其中时间表示为 HH:MM:SS 的格式,时分秒分别用两位十进制数表示(补前导零)。
输入保证时刻依次递增且在 00:00:00 至 23:59:59 的区间内,不用考虑跨过零点充电的情况。
输出格式
输出一个整数,表示总共通电的电能为多少焦耳,其中 1 焦耳等于 1 伏乘以1 安乘以 1 秒。
样例输入
3 12:00:00 12 1 12:01:02 5 2 12:01:10 0 0
样例输出
824
评测用例规模与约定
对于所有评测用例,1 <= n <= 100, 0 <= U, I <= 100
#include<stdio.h> int main() { int n; int h[100],m[100],s[100],v[100],i[100]; int h1,m1,s1; int t1=0; int sum=0; scanf("%d",&n); for(int i1=0;i1<n;i1++) { scanf("%d:%d:%d %d %d",&h[i1],&m[i1],&s[i1],&v[i1],&i[i1]); } for(int j=1;j<n;j++) { h1=h[j]-h[j-1]; m1=m[j]-m[j-1]; s1=s[j]-s[j-1]; // printf("\nh=%d",h1); //printf("\nm=%d",m1); // printf("\ns[j]=%d,s[0]=%d",s[j],s[j-1]); //printf("\ns=%d\n",s[j]-s[j-1]); if(h1!=0) { sum+=h1*3600*v[j-1]*i[j-1]; if(m1!=0) { sum+=m1*60*v[j-1]*i[j-1]; if(s1!=0) { sum+=s1*v[j-1]*i[j-1]; } else { sum+=0; } } else { sum+=0; } } else { sum+=0; if(m1!=0) { sum+=m1*60*v[j-1]*i[j-1]; if(s1!=0) { sum+=s1*v[j-1]*i[j-1]; } else { sum+=0; } } else { sum+=0; if(s1!=0) { sum+=s1*v[j-1]*i[j-1]; } else { sum+=0; } } } } printf("%d",sum); return 0; }
6.
小蓝每周六、周日都晨跑,每月的 1、11、21、31日也晨跑。其它时间不晨跑。
已知 2022年1月1日是周六,请问小蓝整个2022年晨跑多少天?
#include<stdio.h> int main() { int day[13]={0,31,28,31,30,31,30,31,31,30,31,30,31}; int sum=0; int week=6; for(int m=1;m<=12;m++) { for(int d=1;d<=day[m];d++) { if(d==1||d==11||d==21||d==31||week%7==6||week%7==0) { sum++; } week++;//用来判断周六周天 } } printf("%d",sum);//138 return 0; }
7.核酸日期
问题描述
如果周一做核酸,周二显示核酸天数为 1 天,周三显示 2 天,以此类推,周六显示 5 天,周日显示 6 天。
小蓝在某一天做了一次核酸,请问他的核酸显示为几天。已知做核酸和查看核酸不是在同一天,而且相差不超过 6 天(显示的数为 1 到 6 之间的数)。
输入格式
输入第一行包含一个整数 s ,表示小蓝做核酸是周几。 s 为 1 到 6 依次表示周一到周六,s 为 7 表示周日。
第二行包含一个整数 t ,表示查看核酸是周几。 t 为 1 到 6 依次表示周一到周六,t 为 7 表示周日。
输出格式
输出一行包含一个整数,表示答案。
样例输入
5
2
样例输出
4
评测用例规模与约定
对于所有评测用例,1 < = s , t < = 7 1 <= s, t <= 71<=s,t<=7。
参考答案
判断一下是不是同一周,如果是就直接做差,不是就加7再做差
#include <stdio.h> int main() { int a, b; scanf("%d\n%d",&a,&b); if (b > a) { printf("%d",b-a); } else { printf("%d",b+7-a); } return 0; }
up主比较菜,是个刚学C语言的小白,用csdn就是想把做过的题保留下来没事多看看,也想为和我一样的c语言小白分享一下我的练习题。