图像过滤是把图像中不重要的像素都染成背景色,使得重要部分被凸显出来。现给定一幅黑白图像,要求你将灰度值位于某指定区间内的所有像素颜色都用一种指定的颜色替换。
输入格式:
输入在第一行给出一幅图像的分辨率,即两个正整数M和N(0 < M, N <= 500),另外是待过滤的灰度值区间端点A和B(0 <= A < B <= 255)、以及指定的替换灰度值。随后M行,每行给出N个像素点的灰度值,其间以空格分隔。所有灰度值都在[0, 255]区间内。
输出格式:
输出按要求过滤后的图像。即输出M行,每行N个像素灰度值,每个灰度值占3位(例如黑色要显示为000),其间以一个空格分隔。行首尾不得有多余空格。
输入样例:3 5 100 150 0 3 189 254 101 119 150 233 151 99 100 88 123 149 0 255输出样例:
003 189 254 000 000 000 233 151 099 000 088 000 000 000 255
思路:
这道题首先是按题目要求输入数据,完了找出相应区间内的数据进行替换。记住区间是<=和>=。最后格式化输出即可。
代码:这个代码最后一个运行超时,正在想办法解决,有知道我错误的大神快告诉我。
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
int m = sc.nextInt();
int n = sc.nextInt();
int a = sc.nextInt();
int b = sc.nextInt();
int t = sc.nextInt();
int[][] s = new int[501][501];
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
s[i][j] = sc.nextInt();
if (s[i][j] >= a && s[i][j] <= b) {
s[i][j] = t;
}
}
}
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
if (j == n - 1) {
System.out.printf("%03d\n", s[i][j]);
} else {
System.out.printf("%03d ", s[i][j]);
}
}
}
}
}
代码:这个可以正确运行
#include <iostream>
#include <iomanip>
using namespace std;
int main() {
int n;
int m;
int low, high, color;
cin >> n >> m >> low >> high >> color;
int a[501][501] = {0};
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
cin >> a[i][j];
if (a[i][j] >= low && a[i][j] <= high) {
a[i][j] = color;
}
}
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (j != 0) {
cout << ' ';
}
cout << setfill('0') << setw(3) << a[i][j];
}
cout << endl;
}
return 0;
}