837. 新 21 点

解决 21 点游戏变种问题的动态规划解法

题目描述

在本题中,爱丽丝参与了一个大致基于纸牌游戏“21点”规则的游戏。她从0分开始,每次抽取一个随机数(范围为 1 到 maxPts)并累计分数。每当她的得分达到或超过一个阈值 k 时,游戏结束。问题要求我们计算爱丽丝的得分不超过 n 的概率。

具体规则如下:

  • 爱丽丝从得分 0 开始。
  • 她每次抽取一个 1 到 maxPts 之间的整数作为分数,并将其加入当前得分。
  • 每次抽取的数字是独立且均匀分布的。
  • 爱丽丝将在她的得分达到或超过 k 时停止抽取。
  • 问题要求计算她的得分不超过 n 的概率。

解题分析

这个问题本质上是一个概率计算问题,需要在动态变化的状态下计算特定得分区间内的概率。由于每次抽取的数字在固定范围内,因此我们可以通过动态规划(DP)来解决这个问题。DP的核心思想是将问题拆解为更小的子问题,每个子问题计算某一状态下的概率,最终合成出完整的解。

动态规划解法

动态规划状态设计

我们首先设计一个数组 dp[i] 来表示爱丽丝得分为 i 时,游戏结束的概率。我们的目标是计算从得分 0 开始时,最终得分不超过 n 的概率。显然,得分大于等于 k 时,游戏就结束了。

3.04 OBSERVATION DATA M: Mixed RINEX VERSION / TYPE CHC CHC 19700101 000000 UTC PGM / RUN BY / DATE KEYLAB MARKER NAME KEYLAB MARKER NUMBER CHC CHC OBSERVER / AGENCY 1113366 CHC P5 1.5.4 REC # / TYPE / VERS 1113366 ANT # / TYPE -2060476.9498 4794809.4259 3654671.8175 APPROX POSITION XYZ 0.0000 0.0000 0.0000 ANTENNA: DELTA H/E/N HUACE ANT PHASECENTER COMMENT G 20 C1C L1C D1C S1C C2P L2P D2P S2P C2X L2X D2X S2X C5Q SYS / # / OBS TYPES L5Q D5Q S5Q C5I L5I D5I S5I SYS / # / OBS TYPES R 12 C1C L1C D1C S1C C2C L2C D2C S2C C2P L2P D2P S2P SYS / # / OBS TYPES E 24 C1B L1B D1B S1B C1C L1C D1C S1C C5I L5I D5I S5I C5Q SYS / # / OBS TYPES L5Q D5Q S5Q C7I L7I D7I S7I C7Q L7Q D7Q S7Q SYS / # / OBS TYPES C 36 C2I L2I D2I S2I C7I L7I D7I S7I C6I L6I D6I S6I C2Q SYS / # / OBS TYPES L2Q D2Q S2Q C7Q L7Q D7Q S7Q C6Q L6Q D6Q S6Q C1D L1D SYS / # / OBS TYPES D1D S1D C5D L5D D5D S5D C1C L1C D1C S1C SYS / # / OBS TYPES 1.000 INTERVAL 2024 5 30 9 0 0.0000000 GPS TIME OF FIRST OBS 2024 5 30 9 59 59.0000000 GPS TIME OF LAST OBS G SYS / PHASE SHIFT R SYS / PHASE SHIFT E SYS / PHASE SHIFT C SYS / PHASE SHIFT C1C 0.000 C1P 0.000 C2C 0.000 C2P 0.000 GLONASS COD/PHS/BIS END OF HEADER > 2024 5 30 9 22 35.0000000 0 52 G05 20877429.600 109711648.475 -992.073 46.750 20877426.643 85489581.633 -773.041 48.250 20877427.041 85489794.626 -773.041 46.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G07 26073065.629 137014840.702 -1755.096 32.000 0.000 0.000 0.000 0.000 26073064.766 106764846.008 -1367.327 31.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G11 23243081.162 122143166.232 -2833.763 40.000 23243082.574 95176462.501 -2208.125 38.000 23243082.543 95176596.495 -2208.088 41.000 23243086.399 91210940.349 -2116.184 39.750 0.000 0.000 0.000 0.000 G13 19950860.409 104842530.711 -362.042 48.000 19950857.007 81695480.017 -282.113 47.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G15 20262485.998 106480185.960 1679.724 47.750 20262483.660 82971600.053 1308.856 49.250 20262484.045 82971842.048 1308.847 48.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G18 23210491.234 121972029.641 3125.751 39.500 23210489.706 95043142.442 2435.645 37.750 23210489.976 95043164.455 2435.580 41.750 23210493.021 91083041.465 2334.188 39.250 0.000 0.000 0.000 0.000 G20 22033261.532 115785563.446 -1783.529 43.000 22033259.184 90222491.367 -1389.763 40.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G23 25100882.999 131906049.927 2480.363 33.250 0.000 0.000 0.000 0.000 25100888.307 102783926.031 1932.786 35.750 25100893.334 98501312.224 1852.331 32.000 0.000 0.000 0.000 0.000 G24 25105739.584 131931637.121 3618.458 29.750 0.000 0.000 0.000 0.000 25105757.424 102803989.201 2819.657 34.000 25105760.222 98520508.066 2702.265 34.000 0.000 0.000 0.000 0.000 G29 21534069.994 113162306.471 -1054.965 45.500 21534068.363 88178406.709 -822.056 47.500 21534068.653 88178470.709 -822.103 44.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 G30 24190857.759 127123902.225 -614.151 35.500 24190859.367 99057551.906 -478.547 32.500 24190859.631 99057684.922 -478.641 37.000 24190859.212 94930293.855 -458.541 37.000 0.000 0.000 0.000 0.000 R01 19446212.819 103951159.511 -217.905 51.500 0.000 0.000 0.000 0.000 19446216.136 80851332.553 -169.523 45.750 R02 21773400.984 116187116.639 2676.776 48.500 0.000 0.000 0.000 0.000 21773408.066 90367953.545 2081.949 44.500 R08 21770875.987 116582032.654 -3276.546 44.000 0.000 0.000 0.000 0.000 21770875.951 90675274.923 -2548.456 43.500 R17 22955903.931 122841700.053 4110.577 43.000 0.000 0.000 0.000 0.000 22955906.633 95543539.551 3197.139 40.750 R23 20479991.800 109554125.837 -2933.336 49.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 R24 19405477.961 103769815.440 1327.125 54.500 0.000 0.000 0.000 0.000 19405479.748 80709953.337 1032.211 50.500 E03 0.000 0.000 0.000 0.000 23785848.093 124995501.215 -1084.693 45.750 0.000 0.000 0.000 0.000 23785848.074 93341190.148 -810.022 45.000 0.000 0.000 0.000 0.000 23785849.975 95776159.000 -831.117 52.750 E05 0.000 0.000 0.000 0.000 26121141.675 137267504.893 -2719.471 31.250 0.000 0.000 0.000 0.000 26121144.853 102505189.905 -2031.042 32.000 0.000 0.000 0.000 0.000 26121146.482 105179236.948 -2083.653 39.500 E07 0.000 0.000 0.000 0.000 27958780.637 146924439.988 2886.197 29.250 0.000 0.000 0.000 0.000 27958796.301 109716402.560 2155.448 32.500 0.000 0.000 0.000 0.000 27958796.695 112578574.469 2211.728 40.250 E08 0.000 0.000 0.000 0.000 23978736.356 126009207.232 1576.980 45.750 0.000 0.000 0.000 0.000 23978735.757 94098131.980 1177.653 44.500 0.000 0.000 0.000 0.000 23978737.670 96552915.900 1208.349 52.500 E13 0.000 0.000 0.000 0.000 25027498.987 131520472.917 2102.470 41.250 0.000 0.000 0.000 0.000 25027500.020 98213459.829 1570.047 40.750 0.000 0.000 0.000 0.000 25027501.785 100775549.598 1611.006 48.500 E15 0.000 0.000 0.000 0.000 23362195.011 122769172.952 -150.446 46.250 0.000 0.000 0.000 0.000 23362195.790 91678463.989 -112.350 46.000 0.000 0.000 0.000 0.000 23362197.607 94070075.203 -115.238 53.750 E34 0.000 0.000 0.000 0.000 26125352.278 137289610.721 -2176.548 38.000 0.000 0.000 0.000 0.000 26125357.403 102521546.076 -1625.339 37.500 0.000 0.000 0.000 0.000 26125358.968 105196027.384 -1667.668 44.750 C01 37550980.860 195537811.101 -2.279 42.500 37550983.035 151202258.190 -1.737 47.000 37550982.569 158890514.592 -1.884 41.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C02 37528192.415 195419149.425 44.287 40.000 37528191.872 151110487.141 34.258 47.750 37528192.434 158794083.012 35.872 41.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C03 36865743.215 191969603.977 7.044 45.250 36865742.619 148443086.335 5.480 49.500 36865741.916 155991042.436 5.753 43.750 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C04 38984941.100 203004837.349 -17.096 38.000 38984942.215 156976218.610 -13.220 44.250 38984941.155 164958044.168 -13.907 37.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C05 39683601.115 206642928.794 42.285 35.000 39683605.705 159789388.992 32.889 42.750 39683603.741 167914326.777 34.419 37.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C06 39495435.307 205663161.804 1708.328 35.500 39495441.059 159032147.026 1321.067 41.500 39495436.893 167118465.900 1388.283 36.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C07 39651246.228 206474419.172 -1630.631 35.750 39651250.448 159659078.583 -1260.848 42.750 39651245.628 167777323.883 -1325.088 36.750 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C08 36603434.414 190603692.890 151.678 44.750 36603431.618 147386973.931 117.323 50.750 36603429.164 154881201.275 123.230 45.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C10 38643041.664 201224439.907 -1675.642 37.750 38643047.296 155599515.968 -1295.735 43.250 38643042.359 163511355.486 -1361.596 37.750 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C11 22503584.568 117182088.349 1522.753 46.750 22503585.350 90612705.844 1177.522 52.750 22503581.883 95220103.070 1237.427 48.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C12 22234928.549 115783096.269 -1780.164 48.000 22234929.910 89531008.857 -1376.472 55.000 22234927.232 94083404.049 -1446.514 50.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C13 36722130.274 191221791.618 220.885 46.250 36722134.926 147864945.177 170.874 49.250 36722131.388 155383474.884 179.538 45.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C16 39409317.964 205214713.634 1714.708 38.500 39409326.883 158685393.772 1325.938 42.500 39409321.289 166754075.114 1393.219 35.750 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 C21 22078926.316 114970780.256 -679.425 51.750 0.000 0.000 0.000 0.000 22078921.392 93423475.999 -552.090 51.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 22078926.336 116025567.925 -685.668 48.250 22078922.784 86642793.979 -511.999 46.000 0.000 0.000 0.000 0.000 C22 24516014.521 127661321.638 -2518.144 41.750 0.000 0.000 0.000 0.000 24516010.297 103735514.429 -2046.239 42.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 24516014.629 128832510.442 -2541.300 37.750 24516010.944 96206366.136 -1897.611 36.500 0.000 0.000 0.000 0.000 C34 21778953.387 113408745.958 -123.956 50.500 0.000 0.000 0.000 0.000 21778953.999 92153996.336 -100.725 50.750 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 21778953.386 114449186.989 -125.077 47.000 21778952.660 85465397.454 -93.379 44.500 0.000 0.000 0.000 0.000 C36 26814858.160 139632004.303 799.385 34.750 0.000 0.000 0.000 0.000 26814866.354 113462478.552 649.679 37.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 26814857.837 140913026.849 806.693 30.500 26814868.322 105227299.528 602.720 32.250 0.000 0.000 0.000 0.000 C38 36328032.270 189169616.383 103.836 48.750 0.000 0.000 0.000 0.000 36328029.763 153715886.332 84.376 49.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 36328032.108 190905109.260 104.802 45.250 36328029.323 142559095.970 78.283 44.000 0.000 0.000 0.000 0.000 C39 38735683.620 201706908.488 1763.052 41.250 0.000 0.000 0.000 0.000 38735683.319 163903716.682 1432.651 41.500 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 38735683.828 203557498.226 1779.208 38.500 38735684.438 152007521.275 1328.574 36.750 0.000 0.000 0.000 0.000 C40 39900486.347 207772264.514 -1875.885 36.250 0.000 0.000 0.000 0.000 39900492.276 168831956.267 -1524.428 37.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 39900485.662 209678391.400 -1892.969 33.250 39900494.765 156577990.200 -1413.659 32.750 0.000 0.000 0.000 0.000 C42 23419200.058 121949987.842 1674.679 45.750 0.000 0.000 0.000 0.000 23419209.938 99094552.113 1360.753 47.250 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 23419200.726 123068854.463 1690.052 42.750 23419211.355 91902239.110 1262.049 41.750 0.000 0.000 0.000 0.000 C43 24248939.680 126270615.346 2390.010 42.750 0.000 0.000 0.000 0.000 24248940.790 102605251.094 1942.010 42.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 24248939.348 127429111.202 2411.818 39.250 24248941.263 95158105.703 1801.062 37.000 0.000 0.000 0.000 0.000 这是什么文件
11-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值