2023华为OD机试 (B卷)|200分图像物体的边界

2023华为OD机试 (B卷)|200分图像物体的边界(Java JavaScript C++ Python)
题目描述
给定一个二维数组M行N列,二维数组里的数字代表图片的像素,为了简化问题,仅包含像素1和5两种像素,每种像素代表一个物体,2个物体相邻的格子为边界,求像素1代表的物体的边界个数。
像素1代表的物体的边界指与像素5相邻的像素1的格子,边界相邻的属于同一个边界,相邻需要考虑8个方向(上,下,左,右,左上,左下,右上,右下)。
其他约束
地图规格约束为:

0 < M < 100
0 < N < 100

① 如下图与像素5的格子相邻的像素1的格子(0,0)(0,1)(0,2)(1,0)(1,2)(2,0)(2,2)(4,4)(4,5)(5,4)为边界,另(0,0)(0,1)(0,2)(1,0)(1,2)(2,0)(2,1)(2,2)相邻,为1个边界,(4,4)(4,5)(5,4)相邻,为1个边界,所以下图边界个数为2

1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
5 1 1 1 1 1
5 1 1 1 1 1
② 如下图,与像素5的格子相邻的像素1的格子`(0,0)(0,1)(0,2)(1,0)(1,2)(2,0)(2,1)(2,2)(3,3)(3,4)(3,5)(4,3)(4,5)(5,3)(5,4)(5,5)`为边界,另这些边界相邻,所以下图边界个数为1。
1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 5 1
1 1 1 1 1 1

注:(2,2)(3,3)相邻

输入描述

第一行,行数M,列数N。
第二行开始,是M行N列的像素的二维数组,仅包含像素1和5

输出描述

像素1代表的物体的边界个数。
如果没有边界输出0(比如只存在像素1,或者只存在像素5)

用例

输入 6 6
1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
输出 2
说明 参考题目描述部分
输入 6 6
1 1 1 1 1 1
1 5 1 1 1 1
1 1 1 1 1 1
1 1 1 1 1 1
1 1 1 1 5 1
1 1 1 1 1 1
输出 2
说明 参考题目描述部分

Java

import java.util.*;

class Main {
   
    static class UnionFindSet {
   
        int[] fa;
        int count;

        public UnionFindSet(int n) {
   
            fa = new int[n];
            for (int i = 0; i < n; i++) {
   
                fa[i] = i;
            }
            count = n;
        }

        public int find(int x) {
   
            if (x != fa[x]) {
   
                fa[x] = find(fa[x]);
            }
            return fa[x];
        }

        public void union(int x, int y) {
   
            int x_fa = find(x);
            int y_fa = find(y);
            if (x_fa != y_fa) {
   
                fa[y_fa] = x_fa;
                count--;
            }
        }
    }

    public static int getBoundaryCount(int[][] matrix, int m, int n) {
   
        List<int[]> brands = new ArrayList<>(); // 存储像素为5的格子的坐标

        // 找到所有像素为5的格子
        for (int i = 0; i < m; i++) {
   
            for (int j = 0; j < n; j++) {
   
                if (matrix[i][j] == 5) {
   
### 回答1: 很高兴能够参加2023华为OD机试(B)。以下是我的回答: 首先,对于我作为一名技术爱好者和计算机科学专业的学生来说,华为OD机试是我展示自己技能和提升职业能力的绝佳机会。我热爱挑战自己,希望能够通过这次机试来展示我的技术水平和解决问题的能力。 另外,作为一家世界知名的科技公司,华为以其创新能力和领导地位而闻名。参加华为OD机试,我希望能够学习到尖端的技术和最佳的工程实践。通过与华为的工程师们交流和学习,我相信我将能够进一步提升自己,掌握更多的技术和知识。 此外,参加华为OD机试也是为了追求个人职业发展的机会。华为作为一家全球性的科技公司,有广阔的市场和众多的职业发展机会。通过参加华为OD机试,我希望能够获得华为的认可,并有机会加入华为,与卓越的团队一起工作,共同推动公司的发展和创新。 最后,我相信参加华为OD机试将是一次富有挑战性和有意义的经历。我会认真准备,研究和了解华为的相关业务和技术要求。我相信通过自己的努力和准备,我将能够展现出自己的实力和能力,为华为做出贡献。 总而言之,参加2023华为OD机试(B)对我而言是一个重要的机会。我将全力以赴,准备充,希望在机试中有出色的表现。我相信通过这次机试,我将能够展现自己的能力,进一步提升自己,并为华为的发展贡献力量。 ### 回答2: 2023华为OD机试(B)是华为公司在2023年举行的一次线上机试。作为华为公司的OD机试,它将通过互联网的方式进行远程评估,为应聘者提供了参与华为招聘的机会。 华为OD机试(B)相对于其他别可能会有一些特殊设计或者难度更高的问题。应聘者需要准备好面对各种类型的算法和编程问题,以及一些与华为相关的项目经验。 首先,准备方面,应聘者需掌握基本的数据结构和算法,熟悉常见的算法题型,如搜索、排序、动态规划等。此外,对于华为相关的项目和技术,应聘者需要了解并掌握相关的核心知识和实践经验。 其次,在机试过程中,要注意时间的合理安排和控制。机试通常时间较紧,应聘者需要快速理解问题,思考解决方案,并高效地实现代码。同时,要注重代码的可读性和优化,保证代码的正确性和效率。 最后,在OD机试结束后,应聘者还可以了解并掌握自己在机试中的不足之处,进一步提升自己的技术能力。同时,可以多关注和了解一些与华为相关的技术和行业动态,为今后的发展做好准备。 总之,参加2023华为OD机试(B)是一次宝贵的机会,应聘者需要提前做好充的准备,掌握技术知识和项目经验,合理安排时间,在机试中发挥自己的优势,同时也要及时总结经验教训,为未来的发展做好准备。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值