6361对角线上的质数-leetcode周赛340第一道-Java

该文章描述了一个LeetCode的编程题目,要求找到给定二维数组nums中位于至少一条对角线上的最大质数。提供的解决方案是一个使用TreeSet存储对角线元素并进行暴力检查的Java实现。算法首先添加对角线元素到排序集合,然后检查取出的每个数是否为质数,直到找到最大质数或集合为空。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

来源:第 340 场周赛 - 力扣(LeetCode)

一、问题描述

* 6361对角线上的质数 显示英文描述  给你一个下标从 0 开始的二维整数数组 nums 。返回位于 nums 至少一条 对角线 上的最大 质数 。
* 如果任一对角线上均不存在质数,返回 0 。注意:     如果某个整数大于 1 ,且不存在除 1 和自身之外的正整数因子,则认为该整数是一个质数。
* 如果存在整数 i ,使得 nums[i][i] = val 或者 nums[i][nums.length - i - 1]= val ,则认为整数 val 位于 nums 的一条对角线上。
* 在上图中,一条对角线是 [1,5,9] ,而另一条对角线是 [3,5,7] 。
* 示例 1:   输入:nums = [ [1,2,3],
* [5,6,7],
* [9,10,11]]
* 输出:11   解释:数字 1、3、6、9 和 11 是所有 "位于至少一条对角线上" 的数字。由于 11 是最大的质数,故返回 11 。
* 示例 2:   输入:nums = [[1,2,3],[5,17,7],[9,11,10]]
* 输出:17   解释:数字 1、3、9、10 和 17 是所有满足"位于至少一条对角线上"的数字。由于 17 是最大的质数,故返回 17 。
* 提示:     1 <= nums.length <= 300     nums.length == numsi.length     1 <= nums[i][j] <= 4*106

二、题解:

直接暴力:

class Solution {
    public int diagonalPrime(int[][] nums) {
        TreeSet<Integer> set = new TreeSet<>(new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                return -( o1 - o2);
            }
        });
        for (int i = 0; i < nums.length; i++) {
            set.add(nums[i][i]);
            set.add(nums[i][nums.length - 1 - i]);
        }

        while (set.size() != 0){
            int num = set.pollFirst();
            if (isDiagonalPrime(num)) return num == 1 ? 0 :num;//这里考虑1的情况

        }

        return 0;
    }

    private boolean isDiagonalPrime(int num) {

        for (int i = 2; i <= num / 2; i++) {
            if (num % i == 0) return false;
        }
        return true;
    }
}

个人测试:

    @Test
    public void  testSolution(){

        int[][][] arr = {
                {{1,2,3},{4,5,6},{7,8,9}},
                {{1,2,3},{5,6,7},{9,10,11}},//11
                {{1,2,3},{5,17,7},{9,11,10}},//17
                {{1}},//1
                {{1,1,1},{1,1,1},{1,1,1}},//1
//                {{},{},{}},
        };

        for (int i = 0; i < arr.length; i++) {
            System.out.println(Arrays.deepToString(arr[i]) + ", result is " + diagonalPrime(arr[i]));
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值