2614. 对角线上的质数-c语言解法

给你一个下标从 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 。

解题代码如下:

c 复制代码
int judge(int a){
    if(a==1){
        return 0;
    }
   for(int i=2;i*i<=a;i++){
       if(a%i==0){
           return 0;

       }
   }
   return 1;
}

int diagonalPrime(int** nums, int numsSize, int* numsColSize){
    int an=-1;
    int col=numsColSize[0];
    for(int i=0;i<numsSize;i++){
        if(judge(nums[i][i])){
            if(nums[i][i]>an){
                an=nums[i][i];
            }
        }
    }
    for(int i=0;i<numsSize;i++){
        if(judge(nums[i][col-i-1])){
            if(nums[i][col-i-1]>an){
                an=nums[i][col-i-1];
            }
        }
    }
    if(an!=-1){
        return an;
    }
    return 0;


}
相关推荐
涛涛北京7 小时前
【算法比较】
算法
yuniko-n7 小时前
【牛客面试 TOP 101】链表篇(二)
算法·链表·职场和发展
少许极端7 小时前
算法奇妙屋(二十三)-完全背包问题(动态规划)
java·算法·动态规划·完全背包
CoderCodingNo7 小时前
【GESP】C++五级练习(贪心思想考点) luogu-P1115 最大子段和
开发语言·c++·算法
Q741_1477 小时前
C++ 队列 宽度优先搜索 BFS 力扣 429. N 叉树的层序遍历 每日一题
c++·算法·leetcode·bfs·宽度优先
txinyu的博客7 小时前
make_shraed & make_unique 替代了new ? 什么场景使用new
开发语言·c++·算法
jinmo_C++7 小时前
Leetcode矩阵
算法·leetcode·矩阵
要加油哦~7 小时前
算法 | 整理数据结构 | 算法题中,JS 容器的选择
前端·javascript·算法
燃于AC之乐10 小时前
我的算法修炼之路--4 ———我和算法的爱恨情仇
算法·前缀和·贪心算法·背包问题·洛谷
MM_MS15 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测