算法练习LeetCode初级算法之数组
删除数组中的重复项

官方解答:

旋转数组

存在重复元素

只出现一次的数

官方解答: 同一个字符进行两次异或运算就会回到原来的值

两个数组的交集 II
|
import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class LeetCode { public static void main(String[] args) { Solution solution = new Solution(); int a[] = {1,2,2 ,1,3}; int n[]= {2,2,3}; System.out.println(Arrays.toString(solution.intersect(a,n))); } } class Solution { public int[] intersect(int[] nums1, int[] nums2) { List<Integer> list=new ArrayList<>(); Arrays.sort(nums1); Arrays.sort(nums2); int n=nums1.length; int m=nums2.length; int j=0; int i=0; while (i<n&&j<m) { if (nums1[i]>nums2[j]) { j++; }else if (nums1[i]<nums2[j]) { i++; }else { list.add(nums1[i]); i++; j++; } } int sum[] = new int[list.size()]; int p=0; for (int k : list) { sum[p]=k; p++; } return sum; } } |
- 加一

这个题目要注意考虑[0]和[9]的情况,还有[9,9,9]的情况!!!
|
class Solution { public int[] plusOne(int[] digits) { for (int i = digits.length-1; i >= 0; i--) { if (digits[i]==9) { digits[i]=0; }else { digits[i]++; return digits; } } int[] sum=new int[digits.length+1]; sum[0]=1; for (int i = 1; i < sum.length; i++) { sum[i]=digits[i-1]; } return sum; } } |
有效数独

我的解法:利用队列,容易理解。
import java.util.LinkedList;
import java.util.Queue;
class Solution {
public boolean isValidSudoku(char[][] board) {
for (int i = 0; i < 9; i++) {
Queue<Character> queue=new LinkedList<>();
for (int j = 0; j < 9; j++) {
if (Character.isDigit(board[i][j])) {
queue.offer(board[i][j]);
}
}
while (!queue.isEmpty()) {
char b=queue.poll();
if (queue.contains(b)) {
return false;
}
}
}
for (int i = 0; i < 9; i++) {
Queue<Character> queue=new LinkedList<>();
for (int j = 0; j < 9; j++) {
if (Character.isDigit(board[j][i])) {
queue.offer(board[j][i]);
}
}
while (!queue.isEmpty()) {
char b=queue.poll();
if (queue.contains(b)) {
return false;
}
}
}
int k=0;
while (k<9) {
Queue<Character> queue=new LinkedList<>();
for (int j = k; j < k+3; j++) {
for (int j2 = 0; j2 < 3; j2++) {
if (Character.isDigit(board[j2][j])) {
queue.offer(board[j2][j]);
}
}
}
while (!queue.isEmpty()) {
char b=queue.poll();
if (queue.contains(b)) {
return false;
}
}
for (int j = k; j < k+3; j++) {
for (int j2 = 3; j2 < 6; j2++) {
if (Character.isDigit(board[j2][j])) {
queue.offer(board[j2][j]);
}
}
}
while (!queue.isEmpty()) {
char b=queue.poll();
if (queue.contains(b)) {
return false;
}
}
for (int j = k; j < k+3; j++) {
for (int j2 = 6; j2 < 9; j2++) {
if (Character.isDigit(board[j2][j])) {
queue.offer(board[j2][j]);
}
}
}
while (!queue.isEmpty()) {
char b=queue.poll();
if (queue.contains(b)) {
return false;
}
}
k+=3;
}
return true;
}
}
官方解答,利用了hashmap键值对,也好理解!
class Solution {
public boolean isValidSudoku(char[][] board) {
// init data
HashMap<Integer, Integer> [] rows = new HashMap[9];
HashMap<Integer, Integer> [] columns = new HashMap[9];
HashMap<Integer, Integer> [] boxes = new HashMap[9];
for (int i = 0; i < 9; i++) {
rows[i] = new HashMap<Integer, Integer>();
columns[i] = new HashMap<Integer, Integer>();
boxes[i] = new HashMap<Integer, Integer>();
}
// validate a board
for (int i = 0; i < 9; i++) {
for (int j = 0; j < 9; j++) {
char num = board[i][j];
if (num != '.') {
int n = (int)num;
int box_index = (i / 3 ) * 3 + j / 3;//此处将数独分配到0-9个3*3的正方格内
// keep the current cell value
rows[i].put(n, rows[i].getOrDefault(n, 0) + 1);
columns[j].put(n, columns[j].getOrDefault(n, 0) + 1);
boxes[box_index].put(n, boxes[box_index].getOrDefault(n, 0) + 1);
// check if this value has been already seen before
if (rows[i].get(n) > 1 || columns[j].get(n) > 1 || boxes[box_index].get(n) > 1)
return false;
}
}
}
return true;
}
}
大神解答,过于难理解,现阶段不要求掌握,仅向大神学习!!!

画红色的部分为遍历3*3的方格内数字是否重复,首先分别将0、1、2和第1行和第2行的每个数比较
然后再用第1行的每个数分别于第2行比较,因为数自身所在的行在前面的for循环中已经比较过了,
所以无需再比较。

- 旋转图像

解答:
class Solution {
public void rotate(int[][] matrix) {
int len=matrix.length;
for (int i = 0; i < len/2; i++) {//外层for循环看有多少层
int start=i;
int end=len-1-i;
for (int j = 0; j < end-start; j++) {//内层for循环看每层要几次循环替换
int temp=matrix[start][start+j];
matrix[start][start+j]=matrix[end-j][start];
matrix[end-j][start]=matrix[end][end-j];
matrix[end][end-j]=matrix[start+j][end];
matrix[start+j][end]=temp;
}
}
}
}
代码看似简单,逻辑实则有些难度!!

外层循环要首先确定两个指针 头:start和尾: end
然后根据普通值来确定二维数组下标,不要根据特殊值,那样没法确定;
由于目前技术有限博客园客户端没有调好,导致格式看起来很难受!!!
算法练习LeetCode初级算法之数组的更多相关文章
- 【LeetCode算法】LeetCode初级算法——字符串
在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...
- 算法练习LeetCode初级算法之字符串
反转字符串 我的解法比较low,利用集合的工具类Collections.reverse反转,用时过长 class Solution { public void reverseString(char[] ...
- 算法练习LeetCode初级算法之链表
删除链表中的节点 /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode ne ...
- 算法练习LeetCode初级算法之数学
Fizz Buzz class Solution { public List<String> fizzBuzz(int n) { List<String> list=new L ...
- 算法练习LeetCode初级算法之设计问题
打乱数组 不断的让第一个与后面随机选择的数交换 class Solution { private int[] nums; private int[] initnums; public Solution ...
- 算法练习LeetCode初级算法之排序和搜索
合并两个有序数组 class Solution { public void merge(int[] nums1, int m, int[] nums2, int n) { System.arrayco ...
- 算法练习LeetCode初级算法之树
二叉树的前序遍历 我的解法:利用递归,自底向下逐步添加到list,返回最终的前序遍历list class Solution { public List<Integer> preorderT ...
- 算法练习LeetCode初级算法之其他
位1的个数 解法一: class Solution { // you need to treat n as an unsigned value public int hammingWeight(int ...
- 算法练习LeetCode初级算法之动态规划
爬楼梯:斐波那契数列 假设你正在爬楼梯.需要 n 阶你才能到达楼顶. 每次你可以爬 1 或 2 个台阶.你有多少种不同的方法可以爬到楼顶呢? 注意:给定 n 是一个正整数. 非递归解法 class S ...
随机推荐
- Introduction of filter in servlet
官方给出的Filter的定义是在请求一个资源或者从一个资源返回信息的时候执行过滤操作的插件.我们使用过滤起最多的场景估计就是在请求和返回时候的字符集转换,或者权限控制,比如一个用户没有登录不能请求某些 ...
- 学习笔记TF025:自编码器
传统机器学习依赖良好的特征工程.深度学习解决有效特征难人工提取问题.无监督学习,不需要标注数据,学习数据内容组织形式,提取频繁出现特征,逐层抽象,从简单到复杂,从微观到宏观. 稀疏编码(Sparse ...
- python中时间、日期、时间戳的转换
1.简介 在编写代码时,往往涉及时间.日期.时间戳的相互转换. 2.示例 # 引入模块 import time, datetime 2.1 str类型的日期转换为时间戳 # 字符类型的时间 tss1 ...
- design_patterns_in_typescript 学习
https://github.com/torokmark/design_patterns_in_typescript Creational Singleton [A class of which on ...
- 3.1 MathType上标位置调整的两种方法
具体操作步骤如下: 1.打开MathType窗口后在工作区域中编辑好公式. 2.调整上标位置有两种方法: (1)选中要调整的上标,按下“Ctrl+↑,Ctrl+↓,Ctrl+←,Ctrl+→”进行调整 ...
- 代码问题:【CF2】
[CF2/CFCF/HCF]: C Ma, JB Huang, X Yang, et al. Hierarchical convolutional features for visual tracki ...
- MySql开启远程账户登陆总结
1.更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"127.0.0.1"改成"% ...
- 如何让Excel单元格中的名字分散对齐
1 操作方式 开始->对齐方式->对齐->水平对齐->分散对齐(缩进) 2 优势 不会破坏数据的有效性
- ORM的多表查询详述
ORM的多表查询 ORM最核心与用的最多的地方就是跨表查询了.这里的"跨表查询"分为以下几种:基于对象的跨表查询.基于双下划线的跨表查询.聚合查询.F与Q查询以及分组查询. 下面就 ...
- ubuntu server cloud img username password
新安装了OpenStack Queens发现无镜像,蹦蹦跳跳的下载了ubuntu的镜像 网址https://cloud-images.ubuntu.com/ 最好你自己找你想要的,vmdk.ova.i ...