LeetCode -- Valid Sudoku
2015-10-05 16:42
211 查看
Question:
Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules.
The Sudoku board could be partially filled, where empty cells are filled with the character
A partially filled sudoku which is valid.
Note:
A valid Sudoku board (partially filled) is not necessarily solvable. Only the filled cells need to be validated.
Anslysis:
问题描述:判断一个数独游戏是否合法。数独当前可以是部分填充,未填充部分用'.'代替。有效地数独并不是指该游戏是否有解,而仅仅判断当前填充是否有效。
数独有效是指:每一行,每一列,以及每个小得九宫格的当前填充是否有重复数字。
思路:看到题目,分析完成后的直接思路是,分别判断数独的每一行,每一列,每九宫格是否含有相同的数字,如果含有就不是有效地数独。
Answer:
Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules.
The Sudoku board could be partially filled, where empty cells are filled with the character
'.'.
A partially filled sudoku which is valid.
Note:
A valid Sudoku board (partially filled) is not necessarily solvable. Only the filled cells need to be validated.
Anslysis:
问题描述:判断一个数独游戏是否合法。数独当前可以是部分填充,未填充部分用'.'代替。有效地数独并不是指该游戏是否有解,而仅仅判断当前填充是否有效。
数独有效是指:每一行,每一列,以及每个小得九宫格的当前填充是否有重复数字。
思路:看到题目,分析完成后的直接思路是,分别判断数独的每一行,每一列,每九宫格是否含有相同的数字,如果含有就不是有效地数独。
Answer:
public class Solution { public boolean isValidSudoku(char[][] board) { //横向判断 for(int i=0; i<board.length; i++) { HashSet<Character> v = new HashSet<Character>(); for(int j=0; j<board[i].length; j++) { if(board[i][j] != '.') { if(!v.contains(board[i][j])) v.add(board[i][j]); else return false; } } } //纵向判断 for(int i=0; i<board[0].length; i++) { HashSet<Character> v = new HashSet<Character>(); for(int j=0; j<board.length; j++) { if(board[j][i] != '.') { if(!v.contains(board[j][i])) v.add(board[j][i]); else return false; } } } //九宫格判断 int i = 0, j = 0; while(i < board.length) { j = 0; while(j < board[0].length) { HashSet<Character> v = new HashSet<Character>(); for(int t=0; t<3; t++) { for(int k=0; k<3; k++) { if(board[i+t][j+k] != '.') { if(!v.contains(board[i+t][j+k])) v.add(board[i+t][j+k]); else return false; } } } j = j + 3; } i = i + 3; } return true; } }
相关文章推荐
- 向null地址copy数据和不断改变指针指向
- javascript中bind()函数实现和应用以及多次bind的结果和参数位置的思考
- 第三周项目2——建设“顺序表”算法库
- Benchmarking And Profiling(性能评测和剖析)
- 第四章项目二建立算法库-单链表
- 第四周项目1---建立单链表
- Ubuntu 14.04 的 SSH 无密码登录
- Perfect Squares - LeetCode 279
- 写点什么吧,作为机器学习分类的开篇……
- 第6周项目1-建立顺序栈算法库
- 第四周 猴子选大王
- 项目4--顺序表应用 问题二
- 第六周项目1-建立顺序栈算法库
- 第四周项目五——猴子选大王
- 第四周项目3-单链表应用(3)递增
- testlink使用
- 半监督情感分类的模糊深度信任网络(Neurocomputing2014)*
- require的定义看不懂【2】
- HTML5权威指南--Web Storage,本地数据库,本地缓存API,Web Sockets API,Geolocation API(简要学习笔记二)
- 【第4周 项目3 - 单链表应用(2)】