中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

java bitmap去重怎么實現

小億
104
2023-10-18 20:05:26
欄目: 編程語言

將Bitmap轉成二進制數組,然后遍歷數組找出重復的像素點,進行去重操作。

以下是一個示例的Java代碼實現:

import java.util.HashSet;
import java.util.Set;
public class BitmapDuplicateRemoval {
public static void main(String[] args) {
int[][] bitmap = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{1, 2, 3, 4},
{9, 10, 11, 12}
};
int[][] result = removeDuplicates(bitmap);
for (int[] row : result) {
for (int pixel : row) {
System.out.print(pixel + " ");
}
System.out.println();
}
}
public static int[][] removeDuplicates(int[][] bitmap) {
Set<Integer> seen = new HashSet<>();
int height = bitmap.length;
int width = bitmap[0].length;
int[][] result = new int[height][width];
for (int i = 0; i < height; i++) {
for (int j = 0; j < width; j++) {
int pixel = bitmap[i][j];
if (!seen.contains(pixel)) {
result[i][j] = pixel;
seen.add(pixel);
}
}
}
return result;
}
}

輸出結果為:

1 2 3 4
5 6 7 8
0 0 0 0
9 10 11 12

在上述代碼中,我們使用了一個HashSet來存儲已經出現過的像素點,如果一個像素點在HashSet中不存在,那么我們將其添加到HashSet中,并將其賦值給結果數組。如果一個像素點已經存在于HashSet中,則將其賦值為0,表示去重。最后返回結果數組。

0
丽江市| 泸定县| 石泉县| 观塘区| 呼玛县| 合肥市| 安义县| 调兵山市| 苏尼特右旗| 获嘉县| 平泉县| 南投县| 宜宾县| 阜阳市| 肇州县| 铜川市| 牡丹江市| 恩施市| 祥云县| 巴彦淖尔市| 拉萨市| 阿拉尔市| 南漳县| 田阳县| 乌恰县| 延庆县| 阿拉善右旗| 万载县| 贞丰县| 天等县| 资兴市| 息烽县| 荔浦县| 吉安县| 武强县| 阜康市| 南漳县| 西乌珠穆沁旗| 新巴尔虎右旗| 延庆县| 涪陵区|