| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> leetcode 数组练习,面试一路绿灯Offer拿到手软 -> 正文阅读 |
|
[数据结构与算法]leetcode 数组练习,面试一路绿灯Offer拿到手软 |
nums1[k–]=nums2[j–]; } } while(j>=0){//即nums2元素还没放完 nums1[k–]=nums2[j–]; } } []( )5、两个数组的交集II [leetcode 350]( ) 1.排序,定义指针来判断 public int[] intersect(int[] nums1, int[] nums2) { Arrays.sort(nums1); Arrays.sort(nums2); int left=0; int right=0; List 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、杨辉三角 [leetcode 118题]( ) 判断特殊情况,第一列和i=j列都是1,其他的都上面的值加上面左边的值,定义二维数组进行帮助 public List<List> generate(int numRows) { List<List> list=new ArrayList<>(); int [][]array=new int[numRows][numRows]; for(int i=0;i<numRows;i++){ List res=new ArrayList<>(); for(int j=0;j<=i;j++){ if(j0||ij){ 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、重塑矩阵 找到其规律进行赋值即可 [leetcode 566题]( ) public int[][] matrixReshape(int[][] mat, int r, int c) { int n=mat.length;//行数 int m=mat[0].length;//列数 if(mn!=rc){ 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、矩阵置零 [leetcode 73题]( ) 先检查第一行和第一列是否有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; } |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 8:32:58- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |