最后更新

三刷

15-Jan-2017

好熟悉的题了,DFS做,注意比如1-3是经过2的,如果2被访问过,那么1-3也是可以的。

public class Solution {
public int numberOfPatterns(int m, int n) {
int[][] path = new int[10][10];
boolean[] visited = new boolean[10]; /*
| 1 | 2 | 3 |
| 4 | 5 | 6 |
| 7 | 8 | 9 |
*/
path[1][3] = path[3][1] = 2;
path[1][7] = path[7][1] = 4;
path[3][9] = path[9][3] = 6;
path[9][7] = path[7][9] = 8; path[1][9] = path[9][1] = 5;
path[2][8] = path[8][2] = 5;
path[3][7] = path[7][3] = 5;
path[4][6] = path[6][4] = 5; int res = 0; for (int i = m; i <= n; i++) {
res += 4 * dfs(i - 1, path, visited, 1);
res += 4 * dfs(i - 1, path, visited, 2);
res += dfs(i - 1, path, visited, 5);
} return res;
} public int dfs(int left, int[][] path, boolean[] visited, int pos) {
if (left == 0) {
return 1;
} else {
visited[pos] = true;
int res = 0;
for (int i = 1; i <= 9; i++) {
if (visited[i]) continue;
if (path[i][pos] == 0 || visited[path[i][pos]]) {
res += dfs(left-1, path, visited, i);
}
}
visited[pos] = false;
return res;
} }
}

这个题我真是做得想打人了卧槽。

题目不难,就是算组合,但是因为是3乘3的键盘,所以只需要从1和2分别开始DFS,结果乘以4,再加上5开始的DFS就行了。

问题是这个傻逼题目的设定是,从1到8不需要经过4或者5。。。

我TEST CASE 2,2 卡了好久好久,做得我怀疑人生了,怎么算都是

(3+5)*4 + 8。。结果答案愣是56.

最后发现题设里从1-8是不需要经过4或者5的,真是要报警了。

https://discuss.leetcode.com/topic/63038/how-many-people-thought-from-1-to-8-should-visit-voth-4-and-5)

public class Solution
{
int res = 0;
public int numberOfPatterns(int m, int n)
{ boolean[][] visited = new boolean[3][3];
visited[0][0] = true;
helper(0,0,m,n,1,visited); //System.out.println(res);
visited = new boolean[3][3];
visited[0][1] = true;
helper(0,1,m,n,1,visited);
//System.out.println(res); res *= 4; visited = new boolean[3][3];
visited[1][1] = true;
helper(1,1,m,n,1,visited); return res; } public void helper(int m, int n, int x, int y, int c, boolean[][] visited)
{
if(c >= x && c <= y) res++; for(int i = 0; i < 3;i++)
for(int j = 0; j < 3; j++)
{ if(jumpable(visited,m,n,i,j))
{
visited[i][j] = true;
helper(i,j,x,y,c+1,visited);
visited[i][j] = false; } }
} public boolean jumpable(boolean[][] visited, int m1, int n1, int m2, int n2)
{
if(visited[m2][n2]) return false;
int x = Math.abs(m1-m2);
int y = Math.abs(n1-n2); // adjacent
if(x <= 1 && y <= 1) return true; // di
if(x == 2 && y == 2) return visited[1][1]; // horizontal
if(x == 0 && y == 2) return visited[m1][1]; // vertical
if(x == 2 && y == 0) return visited[1][n1];
/*
if(x == 1 && y == 2) return visited[m1][1] && visited[m2][1];
if(x == 2 && y == 1) return visited[1][n1] && visited[1][n2];
*/
return true; } }



二刷。

08-Nov-2016

这个题光记得一刷的时候颇有怨念,因为跳马子格不算碰到中间2个,卡了好久

https://discuss.leetcode.com/topic/63038/how-many-people-thought-from-1-to-8-should-visit-voth-4-and-5)

还是以 1 2 5分别作为起点,然后1 和 2的要最后乘以4,因为1-9个数字可以转90°转3次。

这次换了个做法,直接标记所有路径,反正也不是很多。

Time: O(n!)

Space: O(n^2)

public class Solution {
public int numberOfPatterns(int m, int n) {
int[][] path = new int[10][10];
/*
| 1 | 2 | 3 |
| 4 | 5 | 6 |
| 7 | 8 | 9 |
*/
path[1][3] = path[3][1] = 2;
path[1][7] = path[7][1] = 4;
path[3][9] = path[9][3] = 6;
path[9][7] = path[7][9] = 8;
path[1][9] = path[9][1] = 5;
path[2][8] = path[8][2] = 5;
path[3][7] = path[7][3] = 5;
path[4][6] = path[6][4] = 5;
int res = 0;
boolean[] visited = new boolean[10];
for (int i = m; i <= n; i++) {
res += 4 * dfs(path, visited, 1, i - 1);
res += 4 * dfs(path, visited, 2, i - 1);
res += dfs(path, visited, 5, i - 1);
}
return res;
} public int dfs(int[][] path, boolean[] visited, int cur, int left) {
if (left == 0) {
return 1;
} else {
int res = 0;
visited[cur] = true;
for (int i = 1; i <= 9; i++) {
if (visited[i]) continue;
if (path[cur][i] == 0 || visited[path[cur][i]]) {
res += dfs(path, visited, i, left - 1);
}
}
visited[cur] = false;
return res;
}
}
}

一刷的办法通过坐标来判断是否经过,也不错……思考起来稍微麻烦点,实际上正解应该是一刷那种不使用N^2空间。

351. Android Unlock Patterns的更多相关文章

  1. [LeetCode] 351. Android Unlock Patterns 安卓解锁模式

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  2. LC 351. Android Unlock Patterns

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  3. [LeetCode] Android Unlock Patterns 安卓解锁模式

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  4. Leetcode: Android Unlock Patterns

    Given an Android 3x3 key ≤ m ≤ n ≤ , count the total number of unlock patterns of the Android lock s ...

  5. Android Unlock Patterns

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  6. [Swift]LeetCode351. 安卓解锁模式 $ Android Unlock Patterns

    Given an Android 3x3 key lock screen and two integers m and n, where 1 ≤ m ≤ n ≤ 9, count the total ...

  7. LeetCode All in One 题目讲解汇总(持续更新中...)

    终于将LeetCode的免费题刷完了,真是漫长的第一遍啊,估计很多题都忘的差不多了,这次开个题目汇总贴,并附上每道题目的解题连接,方便之后查阅吧~ 477 Total Hamming Distance ...

  8. LeetCode All in One题解汇总(持续更新中...)

    突然很想刷刷题,LeetCode是一个不错的选择,忽略了输入输出,更好的突出了算法,省去了不少时间. dalao们发现了任何错误,或是代码无法通过,或是有更好的解法,或是有任何疑问和建议的话,可以在对 ...

  9. Leetcode重点 250题-前400 题

    删除不常考,面试低频出现题目 删除重复代码题目(例:链表反转206题,代码在234题出现过) 删除过于简单题目(例:100题:Same Tree) 删除题意不同,代码基本相同题目(例:136 & ...

随机推荐

  1. iOS中JavaScript和OC交互

    转载自:http://www.devzeng.com/blog/ios-uiwebview-interaction-with-javascript.html 还可参考的文章:http://blog.c ...

  2. php文件粘贴上传

    <?php header("Access-Control-Allow-Origin:*"); $url = 'http://'.$_SERVER['HTTP_HOST']; ...

  3. java基础易错点总结(一)

    子类继承父类表示子类比他的父类包含更多的信息和方法 子类调用重载的构造方法时会调用父类的构造方法,super();一般如果不写的话会隐式的调用,而且每次调用都在所有语句之前. 在函数中,使用父类的地方 ...

  4. java_设计模式_策略模式_Strategy pattern(2016-07-15)

    感受:将算法从方法级别,提升到类级别.之后利用java多态,来切换不同的算法实现不同的功能. 在阎宏博士的<JAVA与模式>一书中开头是这样描述策略(Strategy)模式的: 策略模式属 ...

  5. 最优雅的C++跟lua交互.

    我先来吐槽一下我们这个项目. 我是做手机游戏的, cocos2dx引擎, lua编码. 这本来是一件很欢快的事情, 因为不用接触C++. C++写久了的人写lua, 就会感觉任督二脉被打通了, 代码写 ...

  6. OS X Yosemite下安装Hadoop2.5.1伪分布式环境

    最近开始学习Hadoop,一直使用的是公司配好的环境.用了一段时间后发现对Hadoop还是一知半解,故决定动手在本机上安装一个供学习研究使用.正好自己用的是mac,所以没啥说的,直接安装. 总体流程 ...

  7. js创建对象的三种方法:文本标识法和构造器函数法和返回对象的函数

    文本标识法和定义变量差不多,像这样 var obj = {name:'HanMM','2':'Dali'}; 函数构造器法  先创建一个对象函数 function Obj() { this.addre ...

  8. yii2源码学习笔记(五)

    Event是所有事件类的基类.它封装了与事件相关的参数. yii2\base\Event.php <?php /** * @link http://www.yiiframework.com/ * ...

  9. php之购物车类思路及代码

    <?php /* 购物车类 1.整站范围内,购物车--全局有效 解决:把购物车的信息,放在session里 2.既然全局有效,购物车的实例只有一个 解决:单例模式 技术选型:session+单例 ...

  10. js打开新的窗体不被浏览器阻止

    转载自js弹出新窗口而不会被浏览器阻止的方法有时候希望可以用js另开新窗口,但用window.open方法打开窗口总是被浏览器阻止, 可以用下面的方法打开新窗口而不会遭到拦截 1.新添加一个Form ...