1.剑指Offer编程题之二维数组中的查找

本文介绍了一种在特殊排序的二维数组中查找特定整数的方法,提供了三种不同的算法实现,包括从左下角或右上角开始查找的策略,以及利用二分查找法逐行搜索的方法。

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

题目描述:
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.

解题思路1:
- 从左下角元素开始往上查找,右边元素比这个元素大,上边元素比这个元素小,于是,target比这个元素小就往上找,比这个元素大就往右找.如果出现边界,则查找失败.

C/C++

class Solution{
    public:
    //二维向量这里最外的<>要有空格。否则在比较旧的编译器下无法通过
    bool Find(int target, vector< vector<int> >array){
        if(array.empty()) return false;
        int rows = array.size();
        int cols = array[0].size();
        int i=rows-1,j=0; //左下标元素坐标
        while(i>=0&&j<cols){
            if(target<array[i][j]) --i;
            else if(target>array[i][j]) ++j;
            else return true;
        }
        return false;
    }
};

Python2

class Solution:
    def Find(self,target,array):
        rows = len(array)
        cols = len(array[0])
        i = rows-1
        j = 0
        while j<cols and i>=0:
            if target<array[i][j]:
                i -= 1
            elif target>array[i][j]:
                j += 1
            else:
                return True
        return False

Java

public class Solution{
    public boolean Find(int target, int [][] array){
        int rows = array.length;
        int cols = array[0].length;
        int i = rows-1,j=0;
        while(i>=0&&j<cols){
            if(target<array[i][j])--i;
            else if(target>array[i][j])++j;
            else return true;
        }
        return false;
    }
}

解题思路2:
从右上角开始查找,左边元素比这个元素小,下边元素比这个元素大,于是target比这个元素大,则往下找,比这个元素小则往左找,出现边界查找失败.

C/C++

class Solution{
    public:
    //二维向量这里最外的<>要有空格。否则在比较旧的编译器下无法通过
    bool Find(int target, vector< vector<int> >array){
        if(array.empty())return false;
        int rows = array.size();
        int cols = array[0].size();
        int i=0,j=cols-1;
        while(i<=rows-1&&j>=0){
            if (target<array[i][j])--j;
            else if(target>array[i][j])++i;
            else return true;
        }
        return false;
    }
};

Python2

class Solution:
    def Find(self,target,array):
        rows = len(array)
        cols = len(array[0])
        i = 0
        j = cols-1
        while i<rows-1 and j>=0:
            if target<array[i][j]:
                j -= 1
            elif target>array[i][j]:
                i += 1
            else:
                return True
        return False

Java

public class Solution{
    public boolean Find(int target, int [][] array){
        int rows = array.length;
        int cols = array[0].length;
        int i=0,j=cols-1;
        while(i<=rows-1&&j>=0){
            if(target<array[i][j])--j;
            else if(target>array[i][j])++i;
            else return true;
        }
        return false;
    }
}

解题思路3:
把每一行看成是一个有序递增数组,利用二分法查找,通过遍历每一行得到答案,时间复杂度nlogn.

C/C++

class Solution{
public:
    bool Find(int target,vector< vector<int> >array){
        if(array.empty()) return false;
        int length=array.size();
        for(int i=0;i<length;++i){
            int low = 0;
            int high = array[i].size()-1;
            while(low<=high){
                int mid = (low+high)/2;
                if(target>array[i][mid]) low=mid+1;
                else if(target<array[i][mid]) high=mid-1;
                else return true;
            }
        }
        return false;
    }
};

Python2

class Solution:
    def Find(self,target,array):
        length=len(array)
        for i in range(length):
            low = 0
            high = len(array[i])-1
            while low<=high:
                mid = (low+high)/2
                if target>array[i][mid]:
                    low = mid + 1
                elif target<array[i][mid]:
                    high = mid-1
                else:
                    return True
        return False   

Jave

public class Solution{
    public boolean Find(int target, int [][] array){
        int length=array.length;
        for(int i=0;i<length;++i){
            int low = 0;
            int high = array[i].length-1;
            while(low<=high){
                int mid = (low+high)/2;
                if(target>array[i][mid])low=mid+1;
                else if(target<array[i][mid])high=mid-1;
                else return true;
            }
        }
        return false;
    }
}

本实例均通过牛客网在线编译测试。

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值