IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: 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;

}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-22 11:11:28  更:2021-10-22 11:13:34 
 
开发: 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-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码