✨✨✨【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(八)✨✨✨

🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷

🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷🐷


💚BC72、平均身高

描述:

从键盘输入5个人的身高(米),求他们的平均身高(米)

输入描述:

一行,连续输入5个身高(范围0.00~2.00),用空格分隔

输出描述:

一行,输出平均身高,保留两位小数

示例:

输入:
1.68 1.75 1.82 1.60 1.92

输出:
1.75

代码:

//方法一
#include <stdio.h>
int main()
{
	int i = 0;
	double height[5] = { 0 };
	double sum = 0.0;
	//创建一个数组用来存放这5个数据
	for (i = 0; i < 5; i++)
	{
		scanf("%lf", &height[i]);
	}

	//遍历这个数组,并把每个数加起来
	for (i = 0; i < 5; i++)
	{
		sum += height[i];
	}
	printf("%.2lf\n", sum/5.0);

	return 0;
}

//方法二
//边进行数据的输入 并进行计算
#include <stdio.h>
int main()
{
	double height = 0.0;
	double sum = 0.0;
	int i = 0;
	for (i = 0; i < 5; i++)
	{
		scanf("%lf", &height);
		sum += height;
	}
	printf("%.2lf\n", sum/5.0);

	return 0;
}

结果:

🧡BC74、HTTP状态码

描述:

KiKi访问网站,得到HTTP状态码,但他不知道什么含义,BoBo老师告诉他常见HTTP状态码:200(OK,请求已成功),202(Accepted,服务器已接受请求,但尚未处理。)400(Bad Request,请求参数有误),403(Forbidden,被禁止),404(Not Found,请求失败),500(Internal Server Error,服务器内部错误),502(Bad Gateway,错误网关)

输入描述:

多组输入,一行,一个整数(100~600),表示HTTP状态码

输出描述:

针对每组输入的HTTP状态,输出该状态码对应的含义,具体对应如下:
200-OK
202-Accepted
400-Bad Request
403-Forbidden
404-Not Found
500-Internal Server Error
502-Bad Gateway

示例:

输入:
200

输出:
OK

代码:

#include <stdio.h>
int main()
{
	int http = 0;
	while (~scanf("%d", &http))
	{
		switch (http)
		{
		case 200:
			printf("OK\n");
		break;
			

		case 202:
			printf("Accepted\n");
		break;
		

		case 400:
			printf("Bad Request\n");
		break;
		
		case 403:
			printf("Forbidden\n");
		break;

		case 404:
			printf("Not Found\n");
		break;

		case 500:
			printf("Internal Server Error\n");
		break;

		case 502:
			printf("Bad Gateway\n");
		break;

		}
	}

	return 0;
}

结果:

💛BC75、数字三角形

描述:

KiKi学习了循环,BoBo老师给他出了一系列打印图案的练习,该任务是打印用数字组成的数字三角形图案

输入描述:

多组输入,一个整数(3~20),表示数字三角形边的长度,即数字的数量,也表示输出行数

输出描述:

针对每行输入,输出用数字组成的对应长度的数字三角形,每个数字后面有一个空格

示例:

输入:
4

输出:
1
1 2
1 2 3
1 2 3 4
    
输入:
5

输出:
1
1 2
1 2 3
1 2 3 4
1 2 3 4 5

代码:

#include <stdio.h>
int main()
{
	int a = 0;
	while (~scanf("%d", &a))
	{
		int i = 0;
		//确定几行
		for (i = 0; i < a; i++)
		{
			//打印一行内容
			int j = 1;
			for (j = 1; j < i + 2; j++)
			{
				printf("%d ", j);
			}
			printf("\n");
		}

	}

	return 0;
}

结果:

💙BC76、公务员面试

描述:

公务员面试现场打分。有7位考官,从键盘输入若干组成绩,每组7个分数(百分制),去掉一个最高分和一个最低分,输出每组的平均成绩

输入描述:

一行,输入7个整数(0~100),代表7个成绩,用空格分隔

输出描述:

一行,输出去掉最高分和最低分的平均成绩,小数点后保留2位,每行输出后换行

示例:

输入:
99 45 78 67 72 88 60

输出:
73.00

代码:

//方法一:直接找出最大的和最小的
#include <stdio.h>
int main()
{
	int score = 0;
	int i = 0;
	int sum = 0;
	int max = 0;//定义最大的为0
	int min = 100;//定义最小的为100
	for (i = 0; i < 7; i++)
	{
		scanf("%d", &score);
		sum += score;
		if (max < score)
		{
			max = score;
		}
		if (min > score)
		{
			min = score;
		}
	}
	printf("%.2f\n", (sum - max - min) / 5.0);

	return 0;
}

//通过冒泡排序找出最大的和最小的
#include <stdio.h>
int main()
{
	int i = 0;
	int j = 0;
	int score[8] = { 0 };
	int sum = 0;
	//利用数组创建7个数字
	for (i = 0; i < 7; i++)
	{
		scanf("%d ", &score[i]);
	}
	//遍历数组进行冒泡排序(升序)
	for (j = 0; j < 6; j++)
	{
		int k = 0;
		for (k = 0; k < 6 - j; k++)
		{
			if (score[k] > score[k + 1])
			{
				int tmp = 0;
				tmp = score[k];
				score[k] = score[k + 1];
				score[k + 1] = tmp;
			}
		}
	}
	//对第二个到第六个的数字进行求和
	for (i = 1; i < 6; i++)
	{
		sum += score[i];
	}
	printf("%.2lf\n", sum / 5.0);

	return 0;
}

结果:

💜BC77、有序序列插入一个数字

描述:

有一个有序数字序列,从小到大排序,将一个新输入的数插入到序列中,保证插入新数后,序列仍然是升序

输入描述:

第一行输入一个整数(0≤N≤50)。

第二行输入N个升序排列的整数,输入用空格分隔的N个整数。

第三行输入想要进行插入的一个整数

输出描述:

输出为一行,N+1个有序排列的整数

示例:

输入:
5
1 6 9 22 30
8

输出:
1 6 8 9 22 30

代码:

#include <stdio.h>
int main()
{
	int N = 0;
	int i = 0;
	int M = 0;
	int arr[51] = { 0 };
	//输入个数
	scanf("%d", &N);
	
	//输入升序整数
	for (i = 0; i < N; i++)
	{
		scanf("%d ", &arr[i]);
	}
	
	//输入要插入的数字
	scanf("%d", &M);
	
	//插入的实现
	for (i = N - 1; i >= 0; i--)
	{
		if (arr[i] > M)
		{
			arr[i + 1] =arr[i];
		}
		else
		{
			arr[i + 1] = M;
			break;
		}
	}

	//如果插入的整数小于所有数组中的数
    //此时i = -1,跳出for循环
	if (i < 0)
	{
		arr[0] = M;
	}

	//输出
	for (i = 0; i <= N; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

结果:

扩展:

  1. 从后往前比较,并找到合适的位置,就可以插入数字了
  2. 如果插入的数字比所有的元素都小,那就插入到第一个位置上


🤎BC78、筛选法求素数

描述:

用筛选法求n以内的素数。筛选法求解过程为:将2~n之间的正整数放在数组内存储,将数组中2之后的所有能被2整除的数清0,再将3之后的所有能被3整除的数清0 ,以此类推,直到n为止。数组中不为0的数即为素数

输入描述:

多组输入,每行输入一个正整数(不大于100

输出描述:

针对每行输入的整数n,输出两行,第一行,输出n之内(包括n)的素数,用空格分隔,

第二行,输出数组中2之后0的个数。每行输出后换行

示例:

输入:
20

输出:
2 3 5 7 11 13 17 19
11

代码:

//筛选法
#include <stdio.h>
int main()
{
	int n = 0;
	
	while (~scanf("%d", &n))
	{
		//这里为什么要把数组放在while里面呢
		//因为我们首先要输入n是几,才有素数的集合
		int arr[101];
		int i = 0;
		
		//存储数据 2对应为2的下标 是几就对应几的下标
		for (i = 2; i <= n; i++)
		{
			arr[i] = i;
		}
		
		//列举所有的除数
		int j = 0;
		for (j = 2; j <= n; j++)
		{
			int k = 0;
			
        //进行试除
            for (k = j + 1; k <= n; k++)
			{
				if (arr[k] % j == 0)
				{
					arr[k] = 0;
				}
			}
		}

		//输出并记录
		int count = 0;
		for (i = 2; i <= n; i++)
		{
			if (arr[i] != 0)
			{
				printf("%d ", arr[i]);
			}
			else
			{
				count++;
			}
		}
		printf("\n%d\n", count);
	}

	return 0;
}

//试除法
#include <stdio.h>
int main()
{
	int n = 0;
	
	while (~scanf("%d", &n))
	{
		int i = 0;
		int count = 0;
		for (i = 2; i <= n; i++)
		{
			int j = 0;
			
			for (j = 2; j < i; j++)
			{
				if (i % j == 0)
				{
					count++;
					break;
				}
			}
			if (j == i)
			{
				printf("%d ", i);
			}
		}
		printf("\n%d\n", count);
	}

	return 0;
}

结果:

🖤BC79、图像相似度

描述:

给出两幅相同大小的黑白图像(用0-1矩阵)表示,求它们的相似度。若两幅图像在相同位置上的像素点颜色相同,则称它们在该位置具有相同的像素点。两幅图像的相似度定义为相同像素点数占总像素点数的百分比

输入描述:

第一行包含两个整数m和n,表示图像的行数和列数,用单个空格隔开。1≤m≤100, 1≤n≤100。之后m行,每行n个整数01,表示第一幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开。之后m行,每行n个整数01,表示第二幅黑白图像上各像素点的颜色,相邻两个数用单个空格隔开

输出描述:

一个实数,表示相似度(以百分比的形式给出),精确到小数点后两位

示例:

输入:
3 3
1 0 1
0 0 1
1 1 0
1 1 0
0 0 1
0 0 1

输出:
44.44

代码:

#include <stdio.h>
int main()
{
	int m = 0;
	int n = 0;
	int count = 0;
	int arr1[100][100];
	int arr2[100][100];
	scanf("%d %d", &m, &n);
	
	//把数据存放进第一个二维数组
	int i = 0;
	int j = 0;
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			scanf("%d", &arr1[i][j]);
		}
	}

	//把数据存放进第二个二维数组
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			scanf("%d", &arr2[i][j]);
		}
	}

	//遍历两个二维数组,找出相同的像素点
	for (i = 0; i < m; i++)
	{
		for (j = 0; j < n; j++)
		{
			if(arr1[i][j] == arr2[i][j])
			{
				count++;
			}
		}
	}
	printf("%.2lf\n", 100.0 *count/ (m * n));

	return 0;
}

结果:

扩展:

  1. 创建两个二维数组,存放数据
  2. 遍历二维数组,求出两个二维数组中个数相同的元素


💚BC80、登录验证

描述:

有个软件系统登录的用户名和密码为(用户名:admin,密码:admin),用户输入用户名和密码,判断是否登录成功

输入描述:

多组测试数据,每行有两个用空格分开的字符串,第一个为用户名,第二个位密码

输出描述:

针对每组输入测试数据,输出为一行,一个字符串(“Login Success!”或“Login Fail!”)

示例:

输入:
admin admin

输出:
Login Success!

    
输入:
admin abc

输出:
Login Fail!

代码:

#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[100] = { 0 };
	char arr2[100] = { 0 };

	while (~scanf("%s  %s", arr1, arr2))
	{
		//注意:两个字符串比较不能够直接比较
		//需要用到库函数strcmp
		//如果符合,返回0
		if (strcmp(arr1, "admin") == 0 && strcmp(arr2, "admin") == 0)
		{
			printf("Login Success!\n");
		}
		else
		{
			printf("Login Fail!");
		}
	}

	return 0;
}

结果:

扩展:

🧡BC85、包含数字9的数

描述:

今年是2019年,KiKi想知道1~2019中有多少个包含数字9的数。包含数字的数是指有某一位是“9”的数,例如“2019”、“199”等

输入描述:

输出描述:

一行,一个整数,表示1~2019中共有多少个数包含数字9

代码:

#include <stdio.h>
int main()
{
	//产生1到2019的数字
	int i = 0;
	int count = 0;
	for (i = 0; i <= 2019; i++)
	{
		int m = i;
		//判断是否含有9
		while (m)
		{
			if (m % 10 == 9)
			{
				count++;
				break;
			}
			m /= 10;
		}
	}
	printf("%d\n", count);

	return 0;
}

结果:

扩展:

假设我们这里少了break会怎么样?

少了break就可以计算出输入一个数字,里面有多少个9

代码:

#include <stdio.h>
int main()
{
	int a = 0;
	int count = 0;
	scanf("%d", &a);
	while (a)
	{
		if (a % 10 == 9)
		{
			count++;
		}
		a /= 10;
	}
	printf("%d\n", count);

	return 0;
}

结果:

int m = i;这行代码起什么作用?

假如没有这行代码,我们进入调试

第一次进入for循环i= 0

第二次进入for循环i++等于1

经过while判断条件之后,i又等于0

第三次进入for循环i++等于1

经过while判断之后,i又等于0

我们可以发现这样下去其实是一个死循环


💛BC86、奇偶统计

描述:

任意输入一个正整数N,统计1~N之间奇数的个数和偶数的个数,并输出

输入描述:

一行,一个正整数N。(1≤N≤100,000

输出描述:

一行,1~N之间奇数的个数和偶数的个数,用空格分开

示例:

输入:
5

输出:
3 2

代码:

//方法一:奇数 偶数分别统计
#include <stdio.h>
int main()
{
	int N = 0;
	int i = 0;
	int odd = 0;
	int even = 0;
	scanf("%d", &N);
	for (i = 1; i <= N; i++)
	{
		int m = i;
		//计算出奇数个数
		if (m % 2 != 0)
		{
			odd++;
		}
		//计算出偶数个数
        if (m % 2 == 0)
		{
			even++;
		}
	}
	
	printf("%d %d\n", odd, even);

	return 0;
}

//方法二:计算出计数 然后总体减去奇数就是偶数个数
#include <stdio.h>
int main()
{
	int N = 0;
	int i = 0;
	int odd = 0;
	int even = 0;
	scanf("%d", &N);
	for (i = 0; i <= N; i++)
	{
		int m = i;
		if (m % 2 != 0)
		{
			odd++;
		}
	}
	even = N - odd;
	printf("%d %d", odd, even);


	return 0;
}

//方法三:通过规律进行归纳
#include <stdio.h>
int main()
{
	int N = 0;
	scanf("%d", &N);
	if (N % 2 == 0)
	{
		printf("%d %d", N / 2, N / 2);
	}
	else
	{
		printf("%d %d", N / 2 + 1, N / 2);
	}

	return 0;
}

结果:

扩展:

我们在分析同一道题目的时候,往往有多种方法去求解。

离开前,别忘了👍关注💡收藏💖
希望本文能够对大家有帮助~!


🚀🚀🚀🚀🚀🚀🚀🚀🚀🚀🚀 往期刷题文章分享🚀🚀🚀🚀🚀🚀🚀🚀🚀🚀🚀

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(一)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(二)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(三)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(四)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(五)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(六)

【C语言】带你用最短的时间刷题(附解题思路、具体代码)不断更新(七)

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值