C习题集64-73

目录

64.平均身高

65.HTTP状态码

66.数字三角形

67.公务员面试

68.在有序序列插入一个数

69.筛选法求素数

70.图像相似度

71.验证登录

72.包含数字9的数

73.奇偶统计


64.平均身高

题目描述:

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

输入描述

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

示例输入:1.68 1.75 1.82 1.60 1.92

输入描述:

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

示例输出:1.75

解析:

        本题需要知道在输入身高的同时就可以进行计算,不用非要等到数据全部输入完成再计算。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	double high = 0.0;
	int i = 0;
	double sum = 0.0;
	for (i = 0; i < 5; i++)
	{
		scanf("%lf", &high);
		sum += high;
	}
	printf("%.2lf", sum/5.0);
	return 0;
}

65.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状态码。

示例输入:200

输入描述:

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

示例输出:OK

解析:

        1.多组输入

        2.本题的状态码,且为整数,所以可以考虑用switch语句。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int state = 0;
	while ((scanf("%d", &state)) != EOF)
	{
		switch (state)
		{
		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;
}

66.数字三角形

题目描述:

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

输入描述

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

示例输入:5

输入描述:

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

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

解析:

        1.多组输入

        2.分析清楚每行打印的内容就行了

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;
	while (~scanf("%d", &n))
	{
		int i = 1;
		//一共打印i行
		for (i = i; i <= n; i++)
		{
			//打印一行的内容
			int j = 1;
			for (j = 1; j <= i; j++)
			{
				printf("%d ", j);
			}
			printf("\n");
		}
	}
	return 0;
}

67.公务员面试

题目描述:

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

输入描述

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

示例输入:99 45 78 67 72 88 60

输入描述:

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

示例输出:73.00

解析:

        本题可以一边输入,一边求和,并寻找最大值、最小值,算出平均值。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#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 (score > max)
			max = score;
		if (score < min)
			min = score;
	}
	printf("%.2lf\n",(sum - max - min) / 5.0);
	return 0;
}

68.在有序序列插入一个数

题目描述:

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

输入描述

第一行输入一个整数(0≤N≤50)。
第二行输入N个升序排列的整数,输入用空格分隔的N个整数。
第三行输入想要进行插入的一个整数。

示例输入:
        5
        1 6 9 22 30
        8

输入描述:

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

示例输出:1 6 8 9 22 30

解析:

        如果插入的位置比所有元素都要小,此时就要另作处理,直接把要插入的元素放到第一个位置上。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;//个数
	int arr[51] = { 0 };
	int m = 0;//要插入的数字
	scanf("%d", &n);
	int i = 0;
	//输入有序数组
	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;
		}
	}
	//要插入的元素小于所有元素
	if (i < 0)
	{
		arr[0] = m;
	}
	for (i = 0; i < n + 1; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

69.筛选法求素数

题目描述:

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

输入描述

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

示例输入:20

输入描述:

针对每行输入的整数n,输出两行,第一行,
输出n之内(包括n)的素数,用空格分隔,
第二行,输出数组中2之后0 的个数。每行输出后换行。
示例输出:
         2 3 5 7 11 13 17 19
         11

解析:

        本题需要掌握判断素数的方法:筛选法和试除法

代码:

筛选法
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;
	//int arr[n + 1];//变长数组
	int arr[101] = { 0 };
	int count = 0;
	while (~scanf("%d", &n))
	{
		int i = 0;
		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;
				}
			}
		}
		for (i = 2; i <= n; i++)
		{
			if (arr[i] != 0)
			{
				printf("%d ", arr[i]);
			}
			else
			{
				count++;
			}
		}
		printf("\n%d\n", count);
	}
	return 0;
}

试除法
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;
	//int arr[n + 1];//变长数组
	int arr[101] = { 0 };
	int count = 0;
	while (~scanf("%d", &n))
	{
		int i = 0;
		int count = 0;
		for (i = 2; i <= n; i++)
		{
			//判断i是否为素数 - 2-i-1之间的数
			int j = 0;
			for (j = 2; j < i; j++)
			{
				if (i % j == 0)
				{
					count++;
					break;
				}
			}
			//1.j++之后,不满足条件j < i,跳到这里
			//2.break语句跳到这里
			if (j == i)
			{
				printf("%d ", j);
			}
		}
		printf("\n%d\n", count);
	}
	return 0;
}

70.图像相似度

题目描述:

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

输入描述

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

示例输入:
        3 3
        1 0 1
        0 0 1
        1 1 0
        1 1 0
        0 0 1
        0 0 1

输入描述:

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

示例输出:44.44

解析:

        1.输入二维数组

        2.求两个二维数组的相同元素个数

        3.求百分比要注意*100.0,小数点后保留两位

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int m = 0;//行
	int n = 0;//列
	int arr1[100][100] = { 0 };
	int arr2[100][100] = { 0 };
	int count = 0;
	scanf("%d %d", &m, &n);
	int i = 0;
	for (i = 0; i < m; i++)
	{
		int j = 0;
		for (j = 0; j < n; j++)
		{
			scanf("%d", &arr1[i][j]);
		}
	}
	for (i = 0; i < m; i++)
	{
		int j = 0;
		for (j = 0; j < n; j++)
		{
			scanf("%d", &arr2[i][j]);
		}
	}
	for (i = 0; i < m; i++)
	{
		int j = 0;
		for (j = 0; j < n; j++)
		{
			if (arr1[i][j] == arr2[i][j])
			{
				count++;
			}
		}
	}
	printf("%.2lf", 100.0 * count / (m * n));
	return 0;
}

71.验证登录

题目描述:

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

输入描述

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

示例输入:admin admin

输入描述:

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

示例输出:Login Success!

解析:

两个字符串比较大小不能使用==,需要使用strcmp函数,比较的是两个字符串中对应的ASCII码值。

 

 代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
int main()
{
	char name[100] = { 0 };
	char password[100] = { 0 };
	while (~scanf("%s %s", name, password))
	{
		//两个字符串比较相等不可以使用等号
		//应该使用strcmp - 字符串比较函数
		if (strcmp(name, "admin") == 0 && strcmp(password, "admin") == 0)
			printf("Login Success!\n");
		else
			printf("Login Fail!\n");
	}
	return 0;
}

72.包含数字9的数

题目描述:

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

输入描述

输入描述:

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

解析:

        要判断一个数字是否包含9就要看一下这个数字的某一位是否为9就可以,只要遇到一位是9就可以跳出循环。

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int i = 0;
	int count = 0;
	for (i = 1; i <= 2023; i++)
	{
		//判断i是否包含9
		int m = i;
		while (m)
		{
			if (m % 10 == 9)
			{
				count++;
				break;
			}
			m /= 10;
		}
	}
	printf("%d\n", count);
	return 0;
}

73.奇偶统计

题目描述:

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

输入描述

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

示例输入:5

输入描述:

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

示例输出:3 2

解析:

        1.方法一就是统计奇数的个数,再利用总数-奇数=偶数

        2.方法二是根据数字的个数推算

代码:

//方法一
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int odd = 0;//奇数
	int i = 0;
	for (i = 1; i <= n; i++)
	{
		if (i % 2 == 1)
			odd++;
	}
	printf("%d %d", odd, n - odd);
	return 0;
}

//方法二
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	if (n % 2 == 1)//有奇数个数字
		printf("%d %d", n / 2 + 1, n / 2);
	else
		printf("%d %d", n / 2, n / 2);
	return 0;
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值