2023.3.11上机练习

1.灰度直方图
问题描述
  一幅m×n的灰度图像可以用一个二维矩阵表示,矩阵中的每个元素表示对应像素的灰度值。灰度直方图表示图像中具有每种灰度级的象素的个数,反映图像中每种灰度出现的频率。
  假设图像灰度为16级(灰度值从0-15),现给出一个矩阵表示的灰度图像,输出各级灰度的像素个数。
输入说明6
  输入数据第一行为两个整数m 和n分别表示图像的宽度和高度(0<=m,n<=256),其后是n行数据,每行m个整数,分别表示图像各个像素的灰度值。
输出说明
  输出n行数据,每行数据由两个整数组成,分别表示灰度级和该灰度级像素个数,整数之间用空格分隔,灰度级输出顺序为从低到高,如果某灰度级像素个数为0,则不输出该灰度级的统计结果。
输入样例
5 4
0 1 0 2 8
3 4 8 5 9
12 14 10 6 7
1 15 3 6 10
输出样例
0 2
1 2
2 1
3 2
4 1
5 1
6 2
7 1
8 2
9 1
10 2
12 1
14 1
15 1

#include<iostream>
using namespace std;
int main()
{
	int n, m;
	cin >> n >> m;
	int arr[256][256] = { 0 };
	for (int i = 0; i < n; i++)
		for (int j = 0; j < m; j++)
			cin >> arr[i][j];
	int a[16] = { 0 };
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < m; j++)
		{
			if (arr[i][j] == 0)
				a[0]++;
			else if (arr[i][j] == 1)
				a[1]++;
			else if (arr[i][j] == 2)
				a[2]++;
			else if (arr[i][j] == 3)
				a[3]++;
			else if (arr[i][j] == 4)
				a[4]++;
			else if (arr[i][j] == 5)
				a[5]++;
			else if (arr[i][j] == 6)
				a[6]++;
			else if (arr[i][j] == 8)
				a[7]++;
			else if (arr[i][j] == 9)
				a[9]++;
			else if (arr[i][j] == 10)
				a[10]++;
			else if (arr[i][j] == 11)
				a[11]++;
			else if (arr[i][j] == 12)
				a[12]++;
			else if (arr[i][j] == 13)
				a[13]++;
			else if (arr[i][j] == 14)
				a[14]++;
			else if (arr[i][j] == 15)
				a[15]++;
		}
	}
	for (int i = 0; i < 16; i++)
		cout << i << " " << a[i] << endl;
	return 0;
}

在这里插入图片描述

2.求平均值
题目描述:
计算三个整数的平均值,结果保留两位小数。
输入格式:
共一行,包含三个整数,整数之间用空格分隔。
输出格式:
共一行,输出平均值,结果保留两位小数。
输入示例:
20 42 55
输出示例:
39.00

#include<iostream>
using namespace std;
int main()
{
	int a, b, c;
	cin >> a >> b >> c;
	float avg = float(a + b + c) / 3;
	printf("%.2f", avg);
	return 0;
}

在这里插入图片描述

3.字符统计
问题描述
  给出一个字符C和一行文字S,统计在这行文字S中字符C出现的次数。
  程序还需要支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符;当选项关闭时,表示同一个字母的大写和小写看作相同的字符。
输入说明
  输入数据由两行构成。
  第一行包含一个字符C和一个数字n。字符C为大小或小写英文字母。数字n表示大小写敏感选项,当数字n为0时表示大小写不敏感,当数字n为1时表示大小写敏感。字符C和数字n之间用空格分隔。
  第二行为一个字符串S,字符串由大小写英文字母组成,不含空格和其他字符。字符串S长度不超过100。
输出说明
输出字符C在字符串S中出现的次数。
输入样例
样例1输入
L 1
HELLOWorld
样例2输入
L 0
HELLOWorld
输出样例
样例1输出
2
样例2输出
3

#include<iostream>
#include<cctype>
using namespace std;
int main()
{
	char c;
	string s;
	int n;
	cin >> c >> n >> s;
	int count = 0;
	if (n == 0)
	{
		c = tolower(c);
		for (int i = 0; i < s.length(); i++)
		{
			s[i] = tolower(s[i]);
			if (s[i] == c)
				count++;
		}
	}
	else
	{
		for (int i = 0; i < s.length(); i++)
		{
			if (s[i] == c)
				count++;
		}
	}
	cout << count << endl;
	return 0;
}

在这里插入图片描述
在这里插入图片描述

  1. 202012-1原题网址
    在这里插入图片描述
    在这里插入图片描述
#include<iostream>
using namespace std;
int wi[100000], scorei[100000],yi[100000];
int main()
{
	int n;
	cin >> n;
	int s = 0;
	for (int i = 1; i <= n; i++)
	{
		cin >> wi[i] >> scorei[i];
		yi[i] = wi[i] * scorei[i];
		s += yi[i];
	}
	if (max(0, s) > 0)
		cout << s;
	else
		cout << 0;
	return 0;
}

5.202009-1原题网址
在这里插入图片描述

#include<iostream>
#include<algorithm>
using namespace std;
struct dis {
	int num;
	int a;
	int b;
	float distance;
};
bool comp(dis p, dis q)
{
	if (p.distance < q.distance)
		return true;
	else if (p.distance == q.distance)
	{
		if (p.num < q.num)
			return true;
		else
			return false;
	}
	else
		return false;
}
int main()
{
	int n, x, y;
	cin >> n >> x >> y;
	dis s[1000];
	for (int i = 1; i <= n; i++)
	{
		cin >> s[i].a >> s[i].b;
		s[i].num = i;
		s[i].distance = double(s[i].a - x) * double(s[i].a - x) + double(s[i].b - y) * double(s[i].b - y);
	}
	sort(s, s + n, comp);
	for (int i = 1; i <= 3; i++)
		cout << s[i].num << endl;
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值