
🔥个人主页:艾莉丝努力练剑 ❄专栏传送门:《C语言》、《数据结构与算法》、C语言刷题12天IO强训 🍉学习方向:C/C++方向 ⭐️人生格言:为天地立心,为生民立命,为往圣继绝学,为万世开太平

前言:上一篇博客又带大家刷了一些相对来说简单的代码题目,本篇文章我们将继续练习下面的题目。宇宙安全声明:鉴于博主能力有限,本专栏适用于代码小白刷题,大佬们多多包涵(抱拳)!
铸币博主又漏了一道大题。。。今天同第五篇一并放送给大家(谢罪)!
描述: 假设你们社团要竞选社长,有两名候选人分别是A和B,社团每名同学必须并且只能投一票,最终得票多的人为社长. 输入描述: 一行,字符序列,包含A或B,输入以字符0结束。 输出描述: 一行,一个字符,A或B或E,输出A表示A得票数多,输出B表示B得票数多,输出E表示二人得票数相等。

1、本题有很多种解法; 2.、主要就是读取输入数据的问题要解决好,输入有2个结束条件(遇到读取结束EOF,或者'0'); 3、剩余的工作就是统计个数后,然后根据情况按照格式输出。
这里展示一下三种写法——
写法(1):
//代码1
#include <stdio.h>
int main()
{
char arr[100] = {0};
gets(arr);
int i = 0;
int count_a = 0;
int count_b = 0;
while(arr[i] != '0')
{
if(arr[i] == 'A')
{
count_a ++;
}
else if(arr[i] == 'B')
{
count_b ++;
}
i++;
}
if(count_a > count_b)
printf("A");
else if(count_a < count_b)
printf("B");
else
printf("E");
return 0;
}写法(2):
//代码2
#include<stdio.h>
int main()
{
char arr[100] = {0};
gets(arr);
int i = 0;
int flag = 0;
while(arr[i] != '0')
{
if(arr[i] == 'A')
{
flag++;
}
else if(arr[i] == 'B')
{
flag--;
}
i++;
}
if(flag>0)
printf("A");
else if(flag<0)
printf("B");
else
printf("E");
return 0;
}写法(3):
//代码3
#include<stdio.h>
int main()
{
char arr[100] = {0};
int ch = 0;
int flag = 0;
//如果getchar获取了
while(((ch = getchar()) != '0')&& ch != EOF)
{
if(ch == 'A')
{
flag++;
}
else if(ch == 'B')
{
flag--;
}
}
if(flag > 0)
printf("A");
else if(flag < 0)
printf("B");
else
printf("E");
return 0;
}
关于对组输入的题目,一定要处理好多组数据的输入问题,然后考虑循环如何结束。 方法1和方法2,给出了2种多组输入的方法。,写法3是博主第一次敲的时候写的,可以看看——
写法(1):
//方法1
#include <stdio.h>
int main()
{
int n = 0;
while(scanf("%d", &n) != EOF)
{
if(n>=140)
printf("Genius");
}
return 0;
}写法(2):
//方法2
#include <stdio.h>
int main()
{
int n = 0;
//这种写法是因为scanf读取失败返回EOF,EOF是-1,所以按位取反后的结果是0,0为假,可以让循环停止。
while(~scanf("%d", &n))
{
if(n>=140)
printf("Genius");
}
return 0;
}写法(3):
#include <stdio.h>
int main()
{
int i = 0;
int m[i];
scanf("%d",&m[i]);
printf("%s","Genius");
return 0;
}
1、多组输入; 2、数学中的 90的写法,在C语言中直接写是有bug的。
#include <stdio.h>
int main()
{
int i = 0;
int score[i];
scanf("%d",&score[i]);
printf("%s","Perfect");
return 0;
}
这道题很简单,直接代码实现:
#include <stdio.h>
int main()
{
int num = 0;
while(scanf("%d\n",&num) != EOF)
{
if(num >= 60)
{
printf("Pass\n");
}
else
{
printf("Fail\n");
}
}
return 0;
}
这道题也没有什么好说的,代码演示:
#include <stdio.h>
int main()
{
int num = 0;
while(scanf("%d\n",&num) != EOF)
if(num % 2 == 1)
printf("Odd\n");
else
printf("Even\n");
return 0;
}
1.、多组输入; 2.、每组输入接受3个数字,求出最大值,因为成绩不能是负数,所以假设max期初是0 。
代码(1):
#include <stdio.h>
int main()
{
int i = 0;
int score[3] = {0};
while(scanf("%d %d %d",&score[0],&score[1],&score[2]) != EOF)
{
int MAX = 0;
for(int i = 0;i <= 3;i++)
{
if(score[i] > MAX)
MAX = score[i];
}
printf("%d",MAX);
}
return 0;
}代码(2) :
#include "stdio.h"
int main()
{
int num[3] = {0};
while(~scanf("%d%d%d",&num[0],&num[1],&num[2]))
{
int max = 0;
int i = 0;
for(i = 0;i < 3;i++)
{
if(num[i]>max)
{
max = num[i];
}
}
printf("%d\n",max);
}
return 0;
}代码(3):
#include "stdio.h"
int main()
{
int num[3] = {0};
while(~scanf("%d%d%d",&num[0],&num[1],&num[2]))
{
int max = num[0];
int i = 0;
for(i = 1;i < 3;i++)
{
if(num[i]>max)
{
max = num[i];
}
}
printf("%d\n",max);
}
return 0;
}
博主自己先先试着写了写,测试通过:
#include "stdio.h"
int main()
{
int ch = 0;
char vowel[] = "AaEeIiOoUu";
while((ch = getchar()) != EOF)
{
int i = 0;
for(i = 0;i < 10;i++)
{
if(ch == vowel[i])
{
printf("Vowel\n");
break;
}
}
if(i == 10)
{
printf("Consonant\n");
}
getchar();
}
return 0;
}还有三种写法,可以参考一下——
写法(1):
//方法1
#include <stdio.h>
int main()
{
char ch = 0;
char arr[] = "AEIOUaeiou";
while((ch=getchar()) != EOF)
{
int i = 0;
for(i=0; i<10; i++)
{
if(ch == arr[i])
{
printf("Vowel\n");
break;
}
}
if(i == 10)
printf("Consonant\n");
getchar();//去除每个字符后的\n
}
return 0;
}写法(2):
//方法2
#include <stdio.h>
int main()
{
char ch = 0;
char arr[] = "AEIOUaeiou";
//在%c的前面写一个空格会消化掉前面所有的空白字符,然后读取一个字符
while(scanf(" %c", &ch) != EOF)
{
int i = 0;
for(i=0; i<10; i++)
{
if(ch == arr[i])
{
printf("Vowel\n");
break;
}
}
if(i == 10)
printf("Consonant\n");
}
return 0;
}写法(3):
//方法3
#include <stdio.h>
int main()
{
char ch = 0;
char arr[] = "AEIOUaeiou";
//在%c的后边发给一个'\n',其实在输入时候就会消化掉这个\n字符
//不会为下次留下空白字符的隐患
while(scanf("%c\n", &ch) != EOF)
{
int i = 0;
for(i=0; i<10; i++)
{
if(ch == arr[i])
{
printf("Vowel\n");
break;
}
}
if(i == 10)
printf("Consonant\n");
}
return 0;
}
本题和【BC46 判断是元音和还是辅音】的是一个道理的,三种方法均可使用——
#include <stdio.h>
int main()
{
char ch = 0;
while(scanf("%c\n",&ch) != EOF)
{
if((ch >= 'a' && ch <= 'z')||(ch >= 'A' && ch <= 'Z'))
{
printf("%c is an alphabet.\n",ch);
}
else
{
printf("%c is not an alphabet.\n",ch);
}
}
return 0;
}
本地和BC46、BC47题一样,就不多赘言了,我们直接展示代码——
代码(1):
#include <stdio.h>
int main()
{
char ch = 0;
while (scanf("%c", &ch) != EOF)
{
if(ch >= 'A' && ch <= 'Z')
{
printf("%c\n",ch+32);
}
else if(ch >= 'a' && ch <= 'z')
{
printf("%c\n",ch-32);
}
}
return 0;
}代码(2):
#include <stdio.h>
#include "ctype.h"
int main()
{
char ch = 0;
while (~scanf("%c\n", &ch))
{
if(isupper(ch))
{
printf("%c\n",tolower(ch));
}
else if(islower(ch))
{
printf("%c\n",toupper(ch));
}
}
return 0;
}
代码演示:
#include <stdio.h>
int main()
{
int t = 0;
while(scanf("%d\n",&t) != EOF)
{
if(t > 0)
{
printf("%d\n",1);
}
else if(t < 0)
{
printf("%d\n",0);
}
else
{
printf("%.1f\n",0.5);
}
}
return 0;
}
这里就是搞清楚三角形的判断规则,并去一一穷举就行了,因为只有三条边:
#include <stdio.h>
int main()
{
int a = 0;
int b = 0;
int c = 0;
while(~scanf("%d%d%d",&a,&b,&c))
{
if((a+b>c)&&(a+c>c)&&(b+c>a))
{
if(a==b && b==c)
{
printf("Equilateral triangle!\n");
}
else if((a==b && a!=c) || (a==c && a!=b) || (b==c && b!=a))
{
printf("Isosceles triangle!\n");
}
else
{
printf("Ordinary triangle!\n");
}
}
else
{
printf("Not a triangle!\n");
}
}
return 0;
}往期回顾:
【C语言刷题】第四天:继续加量加餐,代码题入门,熟练IO模式
【C语言刷题】第三天:继续加量加餐,代码题入门,熟练IO模式
结语:本篇文章带大家刷了十一道题目,到这里就结束了,希望对友友们有所帮助。本文的代码相对于之后的代码题还是很简单的,小白也能直接上手操作,后面的代码题难度上整体是逐渐递增的,博主控制了难度,这样友友们能比较丝滑地上手敲下去。