C++实现LeetCode数组练习题

 更新时间:2021年08月16日 10:39:34   作者:caiyec  
这篇文章主要介绍了C++实现LeetCode的几道数组练习题,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

1、存在重复元素

排序数组,之后遍历是否有重复的元素

public boolean containsDuplicate(int[] nums) {
        Arrays.sort(nums);
        for(int i=1;i<nums.length;i++){
            if(nums[i-1]==nums[i]){
                return true;
            }
        }
        return false;
    }

不排序,利用set去重,判断长度

public boolean containsDuplicate(int[] nums) {
        HashSet <Integer> set=new HashSet<>();
        for(int i=0;i<nums.length;i++){
            set.add(nums[i]);
        }
        if(set.size()==nums.length){
            return false;
        }
        return true;
    }

2、最大子序和

这道题最经典的思路就是动态规划,取当前数组值和当前数组值加上前一个数组值中取最大值

 public int maxSubArray(int[] nums) {
        int res=nums[0];
        for(int i=1;i<nums.length;i++){
            nums[i]=Math.max(nums[i]+nums[i-1],nums[i]);
            res=Math.max(nums[i],res);
        }
        return res;
    }

还有一种就是记录前i项子序列和小于0就重新赋值为下一个

 public int maxSubArray(int[] nums) {
        int count=nums[0];
        int res=nums[0];
        for(int i=1;i<nums.length;i++){
            if(count<=0){
                count=nums[i];
            }else{
                count+=nums[i];
            }
            res=Math.max(res,count);
        }
        return res;
    }

3、两数之和

利用map,来存储数组值和当前位置,来判断

 public int[] twoSum(int[] nums, int target) {
        HashMap<Integer,Integer> map=new HashMap<>();
        for(int i=0;i<nums.length;i++){
            map.put(nums[i],i);
        }
        for(int i=0;i<nums.length;i++){
            int num=target-nums[i];
            if(map.containsKey(num)&&i!=map.get(num)){
                return new int[]{i,map.get(num)};
            }
        }
        return null;
    }

4、合并两个有序数组

定义变量,遍历比较

public void merge(int[] nums1, int m, int[] nums2, int n) {
     int i=m-1;
     int j=n-1;
     int k=m+n-1;
     while(i>=0&&j>=0){
         if(nums1[i]>nums2[j]){
             nums1[k--]=nums1[i--];
         }else{
             nums1[k--]=nums2[j--];
         }
     }
     while(j>=0){//即nums2元素还没放完
     nums1[k--]=nums2[j--];
       }
    }

5、两个数组的交集II

1.排序,定义指针来判断

 public int[] intersect(int[] nums1, int[] nums2) {
        Arrays.sort(nums1);
        Arrays.sort(nums2);
        int left=0;
        int right=0;
        List<Integer> list=new ArrayList<>();
        while(left<nums1.length&&right<nums2.length){
            if(nums1[left]==nums2[right]){
                list.add(nums1[left]);
                left++;
                right++;
            }else if(nums1[left]<nums2[right]){
                left++;
            }else{
                right++;
            }
        }
        int []arr=new int[list.size()];
        for(int i=0;i<list.size();i++){
            arr[i]=list.get(i);
        }
        return arr;
    }

6、买卖股票的最佳时机

股票问题就是保存数组中最小值,之后用当前数组值减去最小值保留最大的,如果max是负数,就返回0

 public int maxProfit(int[] prices) {
    int max=Integer.MIN_VALUE;
    int min=prices[0];
    for(int i=1;i<prices.length;i++){
         max=Math.max(max,prices[i]-min);
         min=Math.min(prices[i],min);
    }
    if(max<0){
        return 0;
    }
    return max;
    }

7、杨辉三角

判断特殊情况,第一列和i=j列都是1,其他的都上面的值加上面左边的值,定义二维数组进行帮助

 public List<List<Integer>> generate(int numRows) {
       List<List<Integer>> list=new ArrayList<>();
        int [][]array=new int[numRows][numRows];
        for(int i=0;i<numRows;i++){
            List<Integer> res=new ArrayList<>();
            for(int j=0;j<=i;j++){
                if(j==0||i==j){
                    array[i][j]=1;
                }else{
                    array[i][j]=array[i-1][j-1]+array[i-1][j];
                }
                res.add(array[i][j]);
            }
            list.add(res);
        }
        return list;
    }

8、重塑矩阵

找到其规律进行赋值即可

public int[][] matrixReshape(int[][] mat, int r, int c) {
        int n=mat.length;//行数
        int m=mat[0].length;//列数
        if(m*n!=r*c){
            return mat;
        }
        int [][]arr=new int[r][c];
        for(int i=0;i<r*c;i++){
        arr[i/c][i%c]=mat[i/m][i%m];
        }
       return arr;
    }

9、有效的数独

定义二维数组来判断,将存在的数字置为true,判断是否该位置为true,返回false.

 public boolean isValidSudoku(char[][] board) {
        boolean [][] row=new boolean[9][9];//行数
        boolean [][] col=new boolean[9][9];//列数
        boolean [][] box=new boolean[9][9];//格子内
        for(int i=0;i<9;i++){
            for(int j=0;j<9;j++){
                char ch=board[i][j];
                if(ch=='.') continue;
                int curIndex=ch-'1';//计算在哪个位置
                int boxIndex=i/3*3+j/3;// 计算在哪个格子里面
     if(row[i][curIndex]||col[j][curIndex]||box[boxIndex][curIndex]) return false;
                row[i][curIndex]=true;
                col[j][curIndex]=true;
                box[boxIndex][curIndex]=true;
            }
        }
        return true;
    }

10、矩阵置零

先检查第一行和第一列是否有0,定义boolean 变量标记
再利用第一行和第一列作为标记列,遍历整个数组,将中间元素为0的第一行和第一列置为0,
之后遍历整个数组将第一行和第一列的为0的元素的中间元素置为0,之后判断第一行和第一列是否含0,改为0即可

class Solution {
    public void setZeroes(int[][] matrix) {
        boolean row=false;//标记第一行
        boolean col=false;//标记第一列
        int m=matrix.length;//行数
        int n=matrix[0].length;//列数
       //检查第一行是否有0 标记
       for(int i=0;i<n;i++){
           if(matrix[0][i]==0){
               row=true;
               break ;
           }
       }
       //检查第一列是否有0 标记
        for(int i=0;i<m;i++){
            if(matrix[i][0]==0){
                col=true;
                break ;
            }
        }
        //遍历中间元素 把第一行和第一列置为0
        for(int i=1;i<m;i++){
            for(int j=1;j<n;j++){
                if(matrix[i][j]==0){
                    matrix[i][0]=0;
                    matrix[0][j]=0;
                }
            }
        }
        //根据第一行第一列的结果 把中间元素置为0
        for(int i=1;i<m;i++){
            for(int j=1;j<n;j++){
                if(matrix[i][0]==0||matrix[0][j]==0){
                    matrix[i][j]=0;
                }
            }
        }
        //检查第一行是否有最开始为0的
        if(row){
            for(int i=0;i<n;i++){
                matrix[0][i]=0;
            }
        }
        //检查第一列是否有最开始为0的
        if(col){
            for(int i=0;i<m;i++){
                matrix[i][0]=0;
            }
        }
    }
}

总结

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • 基于C++ cin、cin.get()、cin.getline()、getline()、gets()函数的使用详解

    基于C++ cin、cin.get()、cin.getline()、getline()、gets()函数的使用详解

    学C++的时候,这几个输入函数弄的有点迷糊;这里做个小结
    2013-05-05
  • C++中的不规则二维数组实现代码

    C++中的不规则二维数组实现代码

    本文介绍了一个在C++中保存不定长二维数组的数据结构,在这个结构中,我们使用了一个含有指针和数组长度的结构体,用这样的一个结构体构造一个结构体数组,用于存储每一个不定长的数组,感兴趣的朋友一起看看吧
    2024-03-03
  • C ++迭代器iterator在string中使用方法介绍

    C ++迭代器iterator在string中使用方法介绍

    迭代器是一种检查容器内元素并遍历元素的数据类型。迭代器是一个变量,提供对一个容器中的对象的(间接)访问方法,并且定义了容器中对象的范围。迭代器可以指向容器中的某个元素,通过迭代器就可以对非数组(存储空间不连续)的数据结构进行遍历
    2022-10-10
  • C++类和对象实战之Date类的实现方法

    C++类和对象实战之Date类的实现方法

    C++ 标准库没有提供所谓的日期类型,C++ 继承了C语言用于日期和时间操作的结构和函数,这篇文章主要给大家介绍了C++类和对象实战之Date类的实现方法,需要的朋友可以参考下
    2021-12-12
  • C语言通过深度优先搜索来解电梯问题和N皇后问题的示例

    C语言通过深度优先搜索来解电梯问题和N皇后问题的示例

    深度优先搜索即是对一个新发现的节点上如果还关联未探测到的边,就沿此边探测下去,直到发现从原点可达的所有点为止,这里我们就来展示C语言通过深度优先搜索来解电梯问题和N皇后问题的示例
    2016-06-06
  • C++库std::flush的具体使用

    C++库std::flush的具体使用

    std::flush是C++标准库中的一个操作符,用于刷新输出流,本文主要介绍了C++库std::flush的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • COLORREF,COLOR,RGB,CString的转化总结分析

    COLORREF,COLOR,RGB,CString的转化总结分析

    实际的软件开发过程中,常需要用到非.net平台的代码。这时候就可能碰到ColorRef(也就是以int类型代表的颜色值或是以DWORD值表示的颜色)。这跟.net平台下的颜色的相互转换MS并没有直接实现
    2013-09-09
  • Visual Studio 2022下载及配置OpenCV4.5.5的详细过程

    Visual Studio 2022下载及配置OpenCV4.5.5的详细过程

    这篇文章主要介绍了Visual Studio 2022下载及配置OpenCV4.5.5的详细过程,在这里注意下Win10的64位操作系统,在OpenCV官网下载OpenCV4.5.5,安装的是Win pack,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • Matlab利用随机森林(RF)算法实现回归预测详解

    Matlab利用随机森林(RF)算法实现回归预测详解

    这篇文章主要为大家详细介绍了Matlab如何利用随机森林(RF)算法实现回归预测,以及自变量重要性排序的操作,感兴趣的小伙伴可以了解一下
    2023-02-02
  • 关于C++智能指针shared_ptr和unique_ptr能否互转问题

    关于C++智能指针shared_ptr和unique_ptr能否互转问题

    C++中的智能指针最常用的是shared_ptr和unique_ptr,C++新手最常问的问题是我从一个函数中拿到unique_ptr,但要转成shared_ptr才能使用,要怎么转换?同理是否能将shared_ptr转换成unique_ptr,面对这些问题,跟随小编一起看看吧
    2022-05-05

最新评论