写点什么

leetcode 数组练习,java 入门书籍

用户头像
极客good
关注
发布于: 刚刚

4、合并两个有序数组




leetcode 88题


定义变量,遍历比较


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




leetcode 350


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、杨辉三角




leetcode 118题


判断特殊情况,第一列和 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、重塑矩阵




【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
复制代码




找到其规律进行赋值即可


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;

用户头像

极客good

关注

还未添加个人签名 2021.03.18 加入

还未添加个人简介

评论

发布
暂无评论
leetcode 数组练习,java入门书籍