前不久写的这个 软件工程师面试技巧 的系列, 朋友很喜欢, 所以我打算把我毕生所学(哈哈)整理整理分享于大家,望喜欢.另:我觉得:分享就是一种再学习的过程.
给定一个数独,我们要检查是否有效.一个有效的数独横的竖的都只出现1-9的数字各一次,并且9个小宫格里的数字也只出现1-9各一次.
你能快速的告诉我以下是否是个有效的数独么?

数独
我们只需要检查给定的数独中已经填好的数字.最好的方法就是通过 C++中 STL 的 unordered_set (未排序的集合) 来保存已经出的数字.记得检查下一个9宫格或者行或列的时候清空集合便可.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | // https://justyy.com/archive/4998 class Solution { public: bool isValidSudoku(vector<vector<char>>& board) { unordered_set<int> has; for (int i = 0; i < 9; i ++) { has.clear(); // rows = 行 for (int j = 0; j < 9; j ++) { if (board[i][j] != '.') { if (has.count(board[i][j])) { return false; } has.insert(board[i][j]); } } has.clear(); // columns = 列 for (int j = 0; j < 9; j ++) { if (board[j][i] != '.') { if (has.count(board[j][i])) { return false; } has.insert(board[j][i]); } } } for (int i = 0; i < 3; i ++) { for (int j = 0; j < 3; j ++) { // 9 sub grids - 每一个9宫格也要检查 has.clear(); for (int x = i * 3; x < i * 3 + 3; x ++) { for (int y = j * 3; y < j * 3 + 3; y ++) { if (board[x][y] != '.') { if (has.count(board[x][y])) { return false; } has.insert(board[x][y]); } } } } } return true; } }; |
// https://justyy.com/archive/4998 class Solution { public: bool isValidSudoku(vector<vector<char>>& board) { unordered_set<int> has; for (int i = 0; i < 9; i ++) { has.clear(); // rows = 行 for (int j = 0; j < 9; j ++) { if (board[i][j] != '.') { if (has.count(board[i][j])) { return false; } has.insert(board[i][j]); } } has.clear(); // columns = 列 for (int j = 0; j < 9; j ++) { if (board[j][i] != '.') { if (has.count(board[j][i])) { return false; } has.insert(board[j][i]); } } } for (int i = 0; i < 3; i ++) { for (int j = 0; j < 3; j ++) { // 9 sub grids - 每一个9宫格也要检查 has.clear(); for (int x = i * 3; x < i * 3 + 3; x ++) { for (int y = j * 3; y < j * 3 + 3; y ++) { if (board[x][y] != '.') { if (has.count(board[x][y])) { return false; } has.insert(board[x][y]); } } } } } return true; } };
这题并不难,意在考灵活使用数据类型(集合),面试的时候第一个需要思考的就是:这题是否可以用穷举(暴力)来解答? 即使你的暴力不太现实(需要计算力太久,像比特币挖矿一样),但是对于考官来说,这也是解决方法的第一步,之后才会考虑是否可以有其它高效的方法来提速.
英文: How to Check Valid Sudoku in C/C++?
面试经历
- 写了十几年代码, 谷歌/Google认为我还不够Senior
- Jane Street第一轮一小时面试体验卡(伦敦软件工程师)
- Meta/Facebook四次面试经历
- 三次冲击谷歌软件工程师: 我的面试起伏录 (谷歌面试是不是一生只有三次机会?)
- 记两次伦敦抖音面试经历(Tiktok)
- 我的面试谷哥GOOGLE伦敦SRE的经验和教训
- 记Facebook的第一轮技术面试(伦敦脸书)
- 记微软Principal SE的第一轮面试
- 我的AMAZON面试经历与经验之谈(亚麻伦敦面经)
- 离伦敦脸书最近的一次 - 记FACEBOOK伦敦终面经历
面试题
- 软件工程师面试: TCP/IP协议是什么?
- 软件工程师经典面试题: 当你在浏览器的地址栏敲入google.com并按回车后发生了什么?
- 谷歌面试题: 迷宫随机生成算法
- 软件工程师数据库面试技巧之 SQL中的第二名记录
- 软件工程师面试技巧之 动态规化 - 整数拆分
- 软件工程师面试技巧之 如何检查数独的有效性
- 去年 Google 的面试题 - 打印消息
- 软件工程师面试技巧之 使用哈希表降复杂度
- 微软面试题: 三角形的面积是多少?
- 英国 IT公司 电话面试的一些技巧 (程序员)
- C/C++ 中的内存管理器(堆与栈)
- C++的 map 当键(Key)不存在的时候会发生什么?
- 随机数独游戏的算法设计 (Sudoku)
- 经典二叉树的镜像的递归算法
- 谷歌的扔鸡蛋问题
- 面经: Python 的 List 和 Dictionary 有啥区别?
- 逻辑测试系列 - 一种只有4种语句的编程语言 - (1)
- 逻辑测试系列之二 - DECR
- 逻辑测试系列之三 - SUBT
面试技巧
面试其它
- 产品设计和系统设计面的区别(Product Design vs System Design)
- 45 分钟模拟面试(编程、系统设计)+职业发展建议
- 英国和美国IT公司面试的主要区别
- 拒了甲骨文(Oracle)的 Offer
GD Star Rating
loading...
本文一共 376 个汉字, 你数一下对不对.loading...
上一篇: 小白教程: 怎么领取 BCC (Bitcoin Cash) ?
下一篇: 软件工程师面试技巧之: 动态规划/整数拆分
扫描二维码,分享本文到微信朋友圈

手机数独我玩过,代码的字母我认识.
其实我主要为了沙发的,哈哈!
多谢 沙发一定留给你