首页 > 其他分享 >11.1打卡

11.1打卡

时间:2023-11-01 21:34:00浏览次数:33  
标签:digit HashMap int 11.1 boolean board new 打卡

1. 有效的数独(36)

请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。

  1. 数字 1-9 在每一行只能出现一次。
  2. 数字 1-9 在每一列只能出现一次。
  3. 数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图)
class Solution {
    public boolean isValidSudoku(char[][] board) {
     HashMap<Integer, Set<Integer>> row = new HashMap<>();
            HashMap<Integer, Set<Integer>> col = new HashMap<>();
            HashMap<Integer, Set<Integer>> area = new HashMap<>();

            for (int i = 0; i < 9; i++) {
                row.put(i,new HashSet<>());
                col.put(i,new HashSet<>());
                area.put(i,new HashSet<>());
            }


            for (int i = 0; i < 9; i++) {
                for (int j = 0; j <9 ; j++) {
                    char c = board[i][j];
                    if(c=='.') continue;
                    int u = c-'0';
                    int idx = i/3*3+j/3;
                    if(row.get(i).contains(u)||col.get(j).contains(u)||area.get(idx).contains(u))
                        return false;
                    row.get(i).add(u);
                    col.get(j).add(u);
                    area.get(idx).add(u);
                }
            }
            return true;
    }
}

2.解数独

编写一个程序,通过填充空格来解决数独问题

class Solution {
   private boolean[][] line = new boolean[9][9];
    private boolean[][] column = new boolean[9][9];
    private boolean[][][] block = new boolean[3][3][9];
    private boolean valid = false;
    private List<int[]> spaces = new ArrayList<int[]>();

    public void solveSudoku(char[][] board) {
        for (int i = 0; i < 9; ++i) {
            for (int j = 0; j < 9; ++j) {
                if (board[i][j] == '.') {
                    spaces.add(new int[]{i, j});
                } else {
                    int digit = board[i][j] - '0' - 1;
                    line[i][digit] = column[j][digit] = block[i / 3][j / 3][digit] = true;
                }
            }
        }

        recusiveSolveSudoku(board, 0);

    }

    public void recusiveSolveSudoku(char[][] board, int pos) {
        if (pos == spaces.size()) {
            valid = true;
            return;
        }

        int[] space = spaces.get(pos);
        int i = space[0], j = space[1];
        for (int digit = 0; digit < 9 && !valid; ++digit) {
            if (!line[i][digit] && !column[j][digit] && !block[i / 3][j / 3][digit]) {
                line[i][digit] = column[j][digit] = block[i / 3][j / 3][digit] = true;
                board[i][j] = (char) (digit + '0' + 1);
                recusiveSolveSudoku(board, pos + 1);
                line[i][digit] = column[j][digit] = block[i / 3][j / 3][digit] = false;
            }
        }
    }
}

 

标签:digit,HashMap,int,11.1,boolean,board,new,打卡
From: https://www.cnblogs.com/forever-fate/p/17804162.html

相关文章

  • 11.1日记
    数据库设计 需求分析:即分析数据存储的要求,主要产出物有数据流图,数据字典,需求说明书。 概念结构设计:就是设计E-R图,即实体-属性图,与物理实现无关,说明有哪些实体,哪些属性, 逻辑结构设计:将E-R图转成关系模式,即转换为实际的表和表中的列属性。 物理设计:根据生成的表等概念,生成物理数......
  • 11.1每日总结
    今天完成了企业erp的所有子系统的流程图绘制,并且完成了软件构造的随堂那个实验和课下作业,并且做了软考的题,明天继续。 ......
  • 11.1
    此次期中考试,我只得了两分,缺少一个传值的方法,整个程序不能运行,只有单个的jsp页面可以在浏览器显示出来。总之就是我没有好好的学,在周六日也没有好好学习,就看了一下上次的代码程序,并看了看html页面单选框复选框什么的,和页面传值交互的语句,我很自信的认为在其中考试中能够及格,可实际......
  • 11.1学习总结
    importjava.io.FileWriter;importjava.io.IOException;importjava.util.HashSet;importjava.util.Random;importjava.util.Scanner;importjava.util.Set;publicclassMathExerciseGenerator{publicstaticvoidmain(String[]args){intnumExercises=......
  • 11.1算法
    递增的三元子序列给你一个整数数组 nums,判断这个数组中是否存在长度为3的递增子序列。如果存在这样的三元组下标(i,j,k) 且满足i<j<k,使得 nums[i]<nums[j]<nums[k],返回true;否则,返回false。 示例1:输入:nums=[1,2,3,4,5]输出:true解释:任何i<j<k......
  • 代码随想录训练营第二十天打卡(Python)| 654.最大二叉树 、617.合并二叉树 、700.二叉搜
    654.最大二叉树1、使用切片classSolution:defconstructMaximumBinaryTree(self,nums:List[int])->Optional[TreeNode]:iflen(nums)==0:returnNonemax_val=max(nums)max_index=nums.index(max_val)node=T......
  • 打卡
    10月26日:今天学习了建模语言,踢了一场正式的足球比赛,我们以胜利结束比赛,下午我们复习了二叉树的相关知识并且练习了相关习题,然后对于新一章的图的学习开了个头,最后学习了离散数学中的偏序相关知识。......
  • 20231026打卡·
    上午的课程是算法与数据结构中的图。图是一种非常重要的数据结构,用于描述事物之间的关系和连接。在这门课上,我们学习了图的基本概念、表示方法以及常见的图算法。通过理论讲解和实践编程练习,我对图的理解和应用有了更深入的认识。图算法对于解决许多实际问题都非常有用,我会在日常......
  • 20231025打卡
    今天的英语课上,我们进行了一次个人演讲活动,让学生上台用PPT讲解老师之前在课文中留下的三个问题。在这次活动中,有一位名叫刘诗蕊的女孩给我留下了深刻的印象,她的演讲让我感到心动。作为聆听者,我积极参与了这次演讲活动。刘诗蕊的演讲非常出色,她流利的英语表达和自信的姿态给我留......
  • 大二打卡(10.25)
    今天做了什么:英语课,上节课的听写结果出来了,感觉大学老师就是仁慈,这份听写要是高中,早被老师抽八百遍了,感谢英语老师给个机会,下次听写应该是下下周,这次争取一手满分这次课的听力做的还不错,除了一个单词猜错意思选错了,其他的都听对了 今天遇到什么问题:建民的测试,目前搞定了链接,......