Aug-01-2019

居然都4刷了,除了记得我做过之外完全没印象。

居然做出来了。。

对于n来说,我可以选1~n里任意一个,比如我选了3,对方一定会说答案在

[12]或者[4n]中较大的那边,所以还是个MinMax题,总算稍微了有了点MinMax的感觉。

但是1~n选哪个要遍历才行。。

dp[n] = dp[1~i) + i + dp(i~n] (i = 1~n)

class Solution {
public int getMoneyAmount(int n) {
int res = 0;
int[][] dp = new int[n+1][n+1]; dp[1][n] = getMinimalAmount(dp, 1, n); return dp[1][n];
} public int getMinimalAmount(int[][] dp, int l, int r) {
if (l > r) return 0;
if (l + 1 == r) return l;
if (l == r) return 0;
if (dp[l][r] != 0) return dp[l][r]; int tempMinimal = Integer.MAX_VALUE;
for (int i = l; i <= r; i ++) {
int leftPortion = getMinimalAmount(dp, l, i-1);
int currentPay = i;
int rightPortion = getMinimalAmount(dp, i+1, r);
int tempPay = currentPay + Math.max(leftPortion, rightPortion);
tempMinimal = Math.min(tempMinimal, tempPay);
}
dp[l][r] = tempMinimal;
return dp[l][r];
}
}

四刷?

极大极小算法。。还是叫极小极大的。。

首先要看怎么能保证赢。

比如2个数,猜第一个猜第二个都能保证下一轮我们赢定了,为了少交钱,我们猜小的。

比如3个数,猜第二个才能保证下一轮再猜一定能赢。

比如4个数,怎么猜都不能保证下一轮一定赢,所以要猜两轮。第一轮猜1,2,3还是4就很讲究了。

猜1就是num1 + dp[2]4

猜2就是dp[1]1 + num2或者num[1] + dp[3]4

...

4种里每种都算出来,看哪种花费最少,选最少的。

而现在有N种。。。

也是个game theory,我们2次决定中夹杂着对方的决定,对方的决定是对我们最不利的。

所谓最不利,就是我们选一个数之后,答案比我们的数大还是小是由对方决定的,他会看看答案比我们大他赚钱多还是答案比我们小他赚钱多,然后选个他赚钱多的。

所以选完数之后,我们的花费是当前选择的数,加上答案大的花费答案小的花费里大的那个。

而我们的选择是,选哪个数花费最小。

所以就是在每个最大值里选个最小的。

public class Solution {
public int getMoneyAmount(int n) {
if (n <= 1) return 0; int[][] dp = new int[n+1][n+1];
for (int[] num : dp) {
Arrays.fill(num, -1);
} dp[1][n] = guess(1, n, dp); return dp[1][n]; } public int guess(int start, int end, int[][] dp) {
if (start > end) return 0;
if (end == start) return 0;
if (end - start == 1) return start; if (dp[start][end] != -1) return dp[start][end]; int res = Integer.MAX_VALUE;
for (int i = start; i <= end; i++) {
int left = guess(start, i-1, dp);
int right = guess(i+1, end, dp);
int makeSure = Math.max(left, right);
res = Math.min(res, makeSure + i);
}
dp[start][end] = res;
return res;
}
}

一刷

这个题操了。

首先弄懂这个题要求什么就花了好久。

是这个意思……

给1到N的数,让你猜,不管你猜几,猜错了给你猜的数的钱。 猜8,错了,付8元。

然后问你有多少钱才能保证一定能找到答案。

其实可以理解为,不管答案是几,用你现有的钱,总能找到答案。

举个例子,假如有1到10让我猜,现在我有一个亿,我肯定能猜出来。但是问题是我没那么多钱,至少有几块钱能保证我猜出来。

这个题有一个假设,就是假设我不是傻逼。

比如1-10 我猜7,小了,那么结果是8 9 10中一个。接下来我肯定猜9,因为如果没猜中,比9小的话答案就是8,否则是10.

其实这个题,不用在乎答案是几,目的是要一个猜法,按这个猜法,一定能找到答案。

比如刚才的例子,1-10,7+9=16是我们需要的资本,16元保证不管1-10里哪个数是答案,我们都能猜到,最多花16元。

那么7+9是怎么来的?

首先看9

在猜了7之后,有2种可能,一种是答案比7小,一种是答案比7大。

所以答案要么出自1-6 要么出自 8- 10

为了 保证 一定能猜到,我们必须假设出自大的一边。

此时的花费就是当前的7+max(1-6,8-10)

那第一次的7是怎么来的,为什么第一次猜7?

没什么好办法,只能遍历,从1-10 假如猜1会如何,猜2会如何,遍历一次,找到最小的起始点,这里又是最小了。

其实我这种孤陋寡闻的弱智是第一次听说MiniMax这个概念,不是很理解,这个题想了好久才明白。

看代码。。

public class Solution {
public int getMoneyAmount(int n)
{
int[][] dp = new int[n+1][n+1]; return helper(1,n,dp); } public int helper(int left, int right, int[][] dp)
{
if(left < right)
{
if(dp[left][right] != 0) return dp[left][right]; //we already calculated it once, just return. int temp = Integer.MAX_VALUE; for(int n = left; n <= right; n++)
{
temp = Math.min(temp,n+Math.max(helper(left,n-1,dp),helper(n+1,right,dp))); } dp[left][right] = temp;
return temp;
}
else
{
return 0; //not return left, becuase I guess the right one
//thus we dont need to pay for this guess
}
}
}

375. Guess Number Higher or Lower II的更多相关文章

  1. 【LeetCode】375. Guess Number Higher or Lower II 解题报告(Python)

    [LeetCode]375. Guess Number Higher or Lower II 解题报告(Python) 作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://f ...

  2. 不一样的猜数字游戏 — leetcode 375. Guess Number Higher or Lower II

    好久没切 leetcode 的题了,静下心来切了道,这道题比较有意思,和大家分享下. 我把它叫做 "不一样的猜数字游戏",我们先来看看传统的猜数字游戏,Guess Number H ...

  3. LC 375. Guess Number Higher or Lower II

    We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You have to gues ...

  4. [LeetCode] 375. Guess Number Higher or Lower II 猜数字大小之二

    We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You have to gues ...

  5. [LeetCode] 375. Guess Number Higher or Lower II 猜数字大小 II

    We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You have to gues ...

  6. leetcode 374. Guess Number Higher or Lower 、375. Guess Number Higher or Lower II

    374. Guess Number Higher or Lower 二分查找就好 // Forward declaration of guess API. // @param num, your gu ...

  7. Leetcode 375. Guess Number Higher or Lower II

    We are playing the Guess Game. The game is as follows: I pick a number from 1 to n. You have to gues ...

  8. 375 Guess Number Higher or Lower II 猜数字大小 II

    我们正在玩一个猜数游戏,游戏规则如下:我从 1 到 n 之间选择一个数字,你来猜我选了哪个数字.每次你猜错了,我都会告诉你,我选的数字比你的大了或者小了.然而,当你猜了数字 x 并且猜错了的时候,你需 ...

  9. [leetcode]375 Guess Number Higher or Lower II (Medium)

    原题 思路: miniMax+DP dp[i][j]保存在i到j范围内,猜中这个数字需要花费的最少 money. "至少需要的花费",就要我们 "做最坏的打算,尽最大的努 ...

随机推荐

  1. ionic移动开发入门

    学习资料:http://www.ionic.wang http://www.ionicframework.com/

  2. TDirectory.GetLogicalDrives获取本地逻辑驱动器

    使用函数: System.IOUtils.TDirectory.GetLogicalDrives class function GetLogicalDrives: TStringDynArray; s ...

  3. cocos2d-x笔记4: TextField不能删除内容,以及我的解决办法。。。

    3.0正式版,win32下,TextField按下backspace键不能删除内容.网上搜了下,很早就有的问题了,正式版了竟然还不解决... 真心无力吐槽啊!!!这种巨大而又明显的Bug... 从昨天 ...

  4. asp.net管道模型

    查了很多资料,终于大概弄懂管道模型(注意并非指定是asp.net范畴)是个什么概念了,其实就是从Unix移植过来的一种概念,也可以说是一种模式吧(只允许一头读,一头写,并且读完了就会自动消失). as ...

  5. Android Studio的一些技巧和使用注意事项(持续更新)

    1.创建一个项目之后默认是没有assets目录的,可以手动在main目录下创建一个assets目录. 2.

  6. [收藏转贴]WCFRESTFul服务搭建及实现增删改查

    RESTful Wcf是一种基于Http协议的服务架构风格,  RESTful 的服务通常是架构层面上的考虑. 因为它天生就具有很好的跨平台跨语言的集成能力,几乎所有的语言和网络平台都支持 HTTP ...

  7. Flatten Binary Tree to Linked List (LeetCode #114 Medium)(LintCode #453 Easy)

    114. Flatten Binary Tree to Linked List (Medium) 453. Flatten Binary Tree to Linked List (Easy) 解法1: ...

  8. Android 窗口管理

    一.概述 在Android系统中,从设计的角度来看,窗口管理系统是基于C/S模式的.整个窗口系统分为服务端和客户端两大部分,客户端负责请求创建窗口和使用窗口,服务端完成窗口的维护,窗口显示等. 在Cl ...

  9. USACO3.41Closed Fences(几何)

    这题水的真不易..300多行 累死了 对着数据查错啊 枚举每个边上的点到源点 是否中间隔着别的边  每条边划分500份就够了  注意一下与源点在一条直线上的边不算 几何 啊,,好繁琐 参考各种模版.. ...

  10. mysql 限制并发select patch

    限制并发select的patch,代码量很少,主要是为了学习mysql的源码,yy一下. 增加两个全局控制变量: thread_limit_min thread_limit_max 增加一个条件变量: ...