矩阵&滑动窗口|36. 有效的数独 3. 无重复字符的最长子串

题目 :请你判断一个 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;
    }
}
相关推荐
kyle~18 小时前
数学基础---刚体变换(旋转矩阵与平移矩阵)
线性代数·矩阵·机器人·旋转矩阵·平移矩阵
论迹18 小时前
【JavaEE】-- Cookie &&Session
java·java-ee
czhc114007566318 小时前
Java114 LeeCode 翻转二叉树
java
一 乐18 小时前
个人理财系统|基于java+小程序+APP的个人理财系统设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·后端·小程序
盖世英雄酱5813618 小时前
java深度调试技术【第四五章:多线程和幽灵代码】
java·后端
稚辉君.MCA_P8_Java19 小时前
深入理解 TCP;场景复现,掌握鲜为人知的细节
java·linux·网络·tcp/ip·kubernetes
熊猫比分站19 小时前
[特殊字符] Java/Vue 实现体育比分直播系统,支持多端实时更新
java·开发语言·vue.js
lang2015092819 小时前
深入掌握 Maven Settings:从配置到实战
java·maven
scx_link19 小时前
修改JetBrains产品(IntelliJ IDEA 、PyCharm等软件)的默认插件和日志的存储位置
java·pycharm·intellij-idea
BUG?不,是彩蛋!19 小时前
Maven-Java 项目到底解决了什么痛点?
java·servlet·maven