题目 :请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。
数字 1-9 在每一行只能出现一次。
数字 1-9 在每一列只能出现一次。
数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)
题目链接 :有效的数独
解题思路: 简单模拟即可
java
class Solution {
public boolean isValidSudoku(char[][] board) {
int[][] hang=new int[9][10];
int[][] lie=new int[9][10];
int[][] small=new int[9][10];
for(int i=0;i<board.length;i++){
for(int j=0;j<board[0].length;j++){
if(board[i][j]!='.'){
if(hang[i][Character.getNumericValue(board[i][j])]!=1){
hang[i][Character.getNumericValue(board[i][j])]=1;
}else{
return false;
}
if(lie[j][Character.getNumericValue(board[i][j])]!=1){
lie[j][Character.getNumericValue(board[i][j])]=1;
}else{
return false;
}
int numofsmall= (i/3)*3+j/3;
if(small[numofsmall][Character.getNumericValue(board[i][j])]!=1){
small[numofsmall][Character.getNumericValue(board[i][j])]=1;
}else{
return false;
}
}
}
}
return true;
}
}
题目 :给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
题目链接 :无重复字符的最长子串
注意条件:s 由英文字母、数字、符号和空格组成
所以 不能用英文对应数组的方式进行记录
解题思路:滑动窗口+哈希表
java
class Solution {
public int lengthOfLongestSubstring(String s) {
Map<Character, Integer> dic = new HashMap<>();
int i = -1, res = 0, len = s.length();
for(int j = 0; j < len; j++) {
if (dic.containsKey(s.charAt(j)))
i = Math.max(i, dic.get(s.charAt(j)));// 更新左指针 i 因为是滑动窗口 有一些前面的值已经不作数了但没有更新 所以加一个max确保i不回跳 取到一些没有意义的值(也可以遍历删除 但比较麻烦)(实例:abba 建议手推)
dic.put(s.charAt(j), j); // 哈希表记录
res = Math.max(res, j - i); // 更新结果
}
return res;
}
}