XDOJ75灰度直方图-二维数组的使用

问题描述
一幅m×n的灰度图像可以用一个二维矩阵表示,矩阵中的每个元素表示对应像素的灰度值。
灰度直方图表示图像中具有每种灰度级的象素的个数,反映图像中每种灰度出现的频率。
假设图像灰度为16级(灰度值从0-15),现给出一个矩阵表示的灰度图像,输出各级灰度的像素个数。

输入说明
输入数据第一行为两个整数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<stdio.h>
//75.灰度直方图 二维数组的使用
int main(){
	int n,m;
	scanf("%d %d",&n,&m);
	//m行 n列
	int arr[256][256];
	int res[256]={0}; 
	int i,j;
	for(i=0;i<m;i++){
		for(j=0;j<n;j++){
			scanf("%d",&arr[i][j]);
			//关键一步 
			res[arr[i][j]]=res[arr[i][j]]+1;
			//也可写成res[arr[i][j]]++;
			//理解:比如,arr[i][j]的值是8,那就是第i j个元素的灰度值是8,我们逐元素扫描,就给统计直方图里面,8这个灰度值的个数就+1,就是res[8]加1
 			//就是说res[]数组 里面初始值都是0,
			 //然后比如第2个元素(arr[0][1])灰度值为6,则res[6]就统计一次 加上1,也就是说灰度值为6的个数现在变成了1,再来一次就再加一次;
		}
	} 
	//一共15个灰度级 
	for(i=0;i<16;i++){
		//若某个结果为0,灰度个数为0,则不输出 
		if(res[i]!=0){	
			printf("%d %d\n",i,res[i]);
		}
	}
	return 0;
} 

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大龄烤红薯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值