CS-Notes/notes/2016 校招真题题解.md

742 lines
19 KiB
Markdown
Raw Normal View History

2018-02-13 22:59:02 +08:00
<!-- GFM-TOC -->
2018-02-22 14:47:22 +08:00
* [???](#???)
* [1. <20><>??-<2D><>??Git](#1-<2D><>??-<2D><>??git)
* [2. <20><>??-????????](#2-<2D><>??-????????)
* [3. <20><>??-?<3F><>????](#3-<2D><>??-?<3F><>????)
* [4. ???-LUCKY STRING](#4-???-lucky-string)
* [5. ???-Numeric Keypad](#5-???-numeric-keypad)
* [6. ???-Spring Outing](#6-???-spring-outing)
* [7. ???-S-expression](#7-???-s-expression)
* [8. ???-?????????](#8-???-?????????)
* [9. ???-???????](#9-???-???????)
* [10. ???-??????<3F><>](#10-???-??????<3F><>)
* [11. ????-???????](#11-????-???????)
* [12. ????-?????????](#12-????-?????????)
* [13. ????-???Coder](#13-????-???coder)
* [14. ????-?????](#14-????-?????)
* [15. ????-??????](#15-????-??????)
* [16. ????-???](#16-????-???)
* [17. ????-????????????](#17-????-????????????)
* [18. ????-?????????](#18-????-?????????)
* [19. ????-???????](#19-????-???????)
* [20. ???-?????](#20-???-?????)
* [22. ???-?<3F><>??????](#22-???-?<3F><>??????)
* [23. ???-???????](#23-???-???????)
* [24. ???-?????](#24-???-?????)
2018-02-13 22:59:02 +08:00
<!-- GFM-TOC -->
2018-02-22 14:47:22 +08:00
# ???
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????
2018-02-13 22:59:02 +08:00
```java
import java.util.*;
```
```java
public class Solution {
}
```
```java
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while (in.hasNext()) {
}
}
}
```
2018-02-22 14:47:22 +08:00
# 1. <20><>??-<2D><>??Git
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
- ????????
- ??? LCA
2018-02-13 22:59:02 +08:00
```java
private class TreeNode {
int id;
List<TreeNode> childs = new ArrayList<>();
TreeNode(int id) {
this.id = id;
}
}
public int getSplitNode(String[] matrix, int indexA, int indexB) {
int n = matrix.length;
2018-02-22 14:47:22 +08:00
boolean[][] linked = new boolean[n][n]; // ?????????
2018-02-13 22:59:02 +08:00
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
linked[i][j] = matrix[i].charAt(j) == '1';
}
}
TreeNode tree = constructTree(linked, 0);
TreeNode ancestor = LCA(tree, new TreeNode(indexA), new TreeNode(indexB));
return ancestor.id;
}
private TreeNode constructTree(boolean[][] linked, int root) {
TreeNode tree = new TreeNode(root);
for (int i = 0; i < linked[root].length; i++) {
if (linked[root][i]) {
2018-02-22 14:47:22 +08:00
linked[i][root] = false; // ???????????????????????????????????????????
2018-02-13 22:59:02 +08:00
tree.childs.add(constructTree(links, i));
}
}
return tree;
}
private TreeNode LCA(TreeNode root, TreeNode p, TreeNode q) {
if (root == null || root.id == p.id || root.id == q.id) return root;
TreeNode ancestor = null;
int cnt = 0;
for (int i = 0; i < root.childs.size(); i++) {
TreeNode tmp = LCA(root.childs.get(i), p, q);
if (tmp != null) {
ancestor = tmp;
cnt++;
}
}
return cnt == 2 ? root : ancestor;
}
```
2018-02-22 14:47:22 +08:00
# 2. <20><>??-????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
??????????????????????????? 1 ?????<3F><>???????????????<3F><>??
2018-02-13 22:59:02 +08:00
```java
public int countBitDiff(int m, int n) {
return Integer.bitCount(m ^ n);
}
```
2018-02-22 14:47:22 +08:00
# 3. <20><>??-?<3F><>????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????????????????<3F><>? 2 ???????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
?????????????
2018-02-13 22:59:02 +08:00
```html
dp[i, j] = max(dp[i, j-1], prices[j] - prices[jj] + dp[i-1, jj]) { jj in range of [0, j-1] } = max(dp[i, j-1], prices[j] + max(dp[i-1, jj] - prices[jj]))
```
```java
public int calculateMax(int[] prices) {
int n = prices.length;
int[][] dp = new int[3][n];
for (int i = 1; i <= 2; i++) {
int localMax = dp[i - 1][0] - prices[0];
for (int j = 1; j < n; j++) {
dp[i][j] = Math.max(dp[i][j - 1], prices[j] + localMax);
localMax = Math.max(localMax, dp[i - 1][j] - prices[j]);
}
}
return dp[2][n - 1];
}
```
2018-02-22 14:47:22 +08:00
# 4. ???-LUCKY STRING
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
- ?????????<3F><>????????
- ?????<3F><>?????????????????????????????? Set ??????? i ?? j ?????????????? Set ?????????????????? Set ???<3F><>????????????????
2018-02-13 22:59:02 +08:00
```java
Set<Integer> fibSet = new HashSet<>(Arrays.asList(1, 2, 3, 5, 8, 13, 21, 34, 55, 89));
Scanner in = new Scanner(System.in);
String str = in.nextLine();
int n = str.length();
Set<String> ret = new HashSet<>();
for (int i = 0; i < n; i++) {
Set<Character> set = new HashSet<>();
for (int j = i; j < n; j++) {
set.add(str.charAt(j));
int cnt = set.size();
if (fibSet.contains(cnt)) {
ret.add(str.substring(i, j + 1));
}
}
}
String[] arr = ret.toArray(new String[ret.size()]);
Arrays.sort(arr);
for (String s : arr) {
System.out.println(s);
}
```
2018-02-22 14:47:22 +08:00
# 5. ???-Numeric Keypad
2018-02-13 22:59:02 +08:00
```java
private static int[][] canReach = {
{1, 0, 0, 0, 0, 0, 0, 0, 0, 0}, // 0
{1, 1, 1, 1, 1, 1, 1, 1, 1, 1}, // 1
{1, 0, 1, 1, 0, 1, 1, 0, 1, 1}, // 2
{0, 0, 0, 1, 0, 0, 1, 0, 0, 1}, // 3
{1, 0, 0, 0, 1, 1, 1, 1, 1, 1}, // 4
{1, 0, 0, 0, 0, 1, 1, 0, 1, 1}, // 5
{0, 0, 0, 0, 0, 0, 1, 0, 0, 1}, // 6
{1, 0, 0, 0, 0, 0, 0, 1, 1, 1}, // 7
{1, 0, 0, 0, 0, 0, 0, 0, 1, 1}, // 8
{0, 0, 0, 0, 0, 0, 0, 0, 0, 1} // 9
};
private static boolean isLegal(char[] chars, int idx) {
if (idx >= chars.length || idx < 0) return true;
int cur = chars[idx] - '0';
int next = chars[idx + 1] - '0';
return canReach[cur][next] == 1;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int T = Integer.valueOf(in.nextLine());
for (int i = 0; i < T; i++) {
String line = in.nextLine();
char[] chars = line.toCharArray();
for (int j = 0; j < chars.length - 1; j++) {
while (!isLegal(chars, j)) {
if (--chars[j + 1] < '0') {
chars[j--]--;
}
for (int k = j + 2; k < chars.length; k++) {
chars[k] = '9';
}
}
}
System.out.println(new String(chars));
}
}
```
2018-02-22 14:47:22 +08:00
# 6. ???-Spring Outing
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
?????? N = 3??K = 4 ???????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
????????? 0 ??????????????????????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
??? 4 ??????????????????????? 4 ???????? 0 ????????????????????????????????????? 4 ??????????????? 4 ???????????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????????????????<3F>k???????????????????<3F><>???????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
??????????<3F><>?????? 0 ???????????????????????????? 4 ????????????????????<3F><>???????????????????????????????? 1 ????????????????????? 2 ??????????????????????????? 2 ???????? 1 ?????????????????????????????????????
2018-02-13 22:59:02 +08:00
```java
int N = in.nextInt();
int K = in.nextInt();
int[][] votes = new int[N][K + 1];
for (int i = 0; i < N; i++) {
for (int j = 0; j < K + 1; j++) {
int place = in.nextInt();
votes[i][place] = j;
}
}
int ret = 0;
for (int place = K; place > 0; place--) {
int cnt = 0;
for (int i = 0; i < N; i++) {
if (votes[i][place] < votes[i][ret]) {
cnt++;
}
}
if (cnt > N / 2) {
ret = place;
}
}
System.out.println(ret == 0 ? "otaku" : ret);
```
2018-02-22 14:47:22 +08:00
# 7. ???-S-expression
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
# 8. ???-?????????
2018-02-13 22:59:02 +08:00
```java
int N = in.nextInt();
int M = in.nextInt();
int[] scores = new int[N];
for (int i = 0; i < N; i++) {
scores[i] = in.nextInt();
}
for (int i = 0; i < M; i++) {
String str = in.next();
if (str.equals("U")) {
int id = in.nextInt() - 1;
int newScore = in.nextInt();
scores[id] = newScore;
} else {
int idBegin = in.nextInt() - 1;
int idEnd = in.nextInt() - 1;
int ret = 0;
if (idBegin > idEnd) {
int t = idBegin;
idBegin = idEnd;
idEnd = t;
}
for (int j = idBegin; j <= idEnd; j++) {
ret = Math.max(ret, scores[j]);
}
System.out.println(ret);
}
}
```
2018-02-22 14:47:22 +08:00
# 9. ???-???????
2018-02-13 22:59:02 +08:00
```java
HashMap<String, Integer> map = new LinkedHashMap<>();
while (in.hasNextLine()) {
String s = in.nextLine();
String key = s.substring(s.lastIndexOf('\\') + 1);
map.put(key, map.containsKey(key) ? map.get(key) + 1 : 1);
}
List<Map.Entry<String, Integer>> list = new LinkedList<>(map.entrySet());
Collections.sort(list, (o1, o2) -> o2.getValue() - o1.getValue());
for (int i = 0; i < 8 && i < list.size(); i++) {
String[] token = list.get(i).getKey().split(" ");
String filename = token[0];
String line = token[1];
if (filename.length() > 16) filename = filename.substring(filename.length() - 16);
System.out.println(filename + " " + line + " " + list.get(i).getValue());
}
```
2018-02-22 14:47:22 +08:00
# 10. ???-??????<3F><>
2018-02-13 22:59:02 +08:00
```java
public class Main {
private Map<String, Integer> map = new HashMap<>();
public Main() {
map.put("3", 0);
map.put("4", 1);
map.put("5", 2);
map.put("6", 3);
map.put("7", 4);
map.put("8", 5);
map.put("9", 6);
map.put("10", 7);
map.put("J", 8);
map.put("Q", 9);
map.put("K", 10);
map.put("A", 11);
map.put("2", 12);
map.put("joker", 13);
map.put("JOKER ", 14);
}
private String play(String s1, String s2) {
String[] token1 = s1.split(" ");
String[] token2 = s2.split(" ");
CardType type1 = computeCardType(token1);
CardType type2 = computeCardType(token2);
if (type1 == CardType.DoubleJoker) return s1;
if (type2 == CardType.DoubleJoker) return s2;
if (type1 == CardType.Bomb && type2 != CardType.Bomb) return s1;
if (type2 == CardType.Bomb && type1 != CardType.Bomb) return s2;
if (type1 != type2 || token1.length != token2.length) return "ERROR";
for (int i = 0; i < token1.length; i++) {
int val1 = map.get(token1[i]);
int val2 = map.get(token2[i]);
if (val1 != val2) return val1 > val2 ? s1 : s2;
}
return "ERROR";
}
private CardType computeCardType(String[] token) {
boolean hasjoker = false, hasJOKER = false;
for (int i = 0; i < token.length; i++) {
if (token[i].equals("joker")) hasjoker = true;
else if (token[i].equals("JOKER")) hasJOKER = true;
}
if (hasjoker && hasJOKER) return CardType.DoubleJoker;
int maxContinueLen = 1;
int curContinueLen = 1;
String curValue = token[0];
for (int i = 1; i < token.length; i++) {
if (token[i].equals(curValue)) curContinueLen++;
else {
curContinueLen = 1;
curValue = token[i];
}
maxContinueLen = Math.max(maxContinueLen, curContinueLen);
}
if (maxContinueLen == 4) return CardType.Bomb;
if (maxContinueLen == 3) return CardType.Triple;
if (maxContinueLen == 2) return CardType.Double;
boolean isStraight = true;
for (int i = 1; i < token.length; i++) {
if (map.get(token[i]) - map.get(token[i - 1]) != 1) {
isStraight = false;
break;
}
}
if (isStraight && token.length == 5) return CardType.Straight;
return CardType.Sigal;
}
private enum CardType {
DoubleJoker, Bomb, Sigal, Double, Triple, Straight;
}
public static void main(String[] args) {
Main main = new Main();
Scanner in = new Scanner(System.in);
while (in.hasNextLine()) {
String s = in.nextLine();
String[] token = s.split("-");
System.out.println(main.play(token[0], token[1]));
}
}
}
```
2018-02-22 14:47:22 +08:00
# 11. ????-???????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
????????????????????<3F><>????????????????????
2018-02-13 22:59:02 +08:00
- if (val <= A[m]) h = m;
2018-02-22 14:47:22 +08:00
- ??? h ????? m ?????? m - 1????? while ????????????? l < h????????? m - 1 ???????? l <= h??
2018-02-13 22:59:02 +08:00
```java
public int getPos(int[] A, int n, int val) {
int l = 0, h = n - 1;
while (l < h) {
int m = l + (h - l) / 2;
if (val <= A[m]) h = m;
else l = m + 1;
}
return A[h] == val ? h : -1;
}
```
2018-02-22 14:47:22 +08:00
# 12. ????-?????????
2018-02-13 22:59:02 +08:00
```java
public char findFirstRepeat(String A, int n) {
boolean[] hasAppear = new boolean[256];
for (int i = 0; i < n; i++) {
char c = A.charAt(i);
if(hasAppear[c]) return c;
hasAppear[c] = true;
}
return ' ';
}
```
2018-02-22 14:47:22 +08:00
# 13. ????-???Coder
2018-02-13 22:59:02 +08:00
```java
public String[] findCoder(String[] A, int n) {
List<Pair<String, Integer>> list = new ArrayList<>();
for (String s : A) {
int cnt = 0;
String t = s.toLowerCase();
int idx = -1;
while (true) {
idx = t.indexOf("coder", idx + 1);
if (idx == -1) break;
cnt++;
}
if (cnt != 0) {
list.add(new Pair<>(s, cnt));
}
}
Collections.sort(list, (o1, o2) -> (o2.getValue() - o1.getValue()));
String[] ret = new String[list.size()];
for (int i = 0; i < list.size(); i++) {
ret[i] = list.get(i).getKey();
}
return ret;
}
2018-02-22 14:47:22 +08:00
// ???????????? javafx.util.Pair???????????????? Pair ??
2018-02-13 22:59:02 +08:00
private class Pair<T, K> {
T t;
K k;
Pair(T t, K k) {
this.t = t;
this.k = k;
}
T getKey() {
return t;
}
K getValue() {
return k;
}
}
```
2018-02-22 14:47:22 +08:00
# 14. ????-?????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????
2018-02-13 22:59:02 +08:00
```java
public int getDis(int[] A, int n) {
int max = 0;
int soFarMin = A[0];
for (int i = 1; i < n; i++) {
if(soFarMin > A[i]) soFarMin = A[i];
else max = Math.max(max, A[i]- soFarMin);
}
return max;
}
```
2018-02-22 14:47:22 +08:00
# 15. ????-??????
2018-02-13 22:59:02 +08:00
```java
public int[][] flipChess(int[][] A, int[][] f) {
int[][] direction = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};
for (int[] ff : f) {
for (int[] dd : direction) {
int r = ff[0] + dd[0] - 1, c = ff[1] + dd[1] - 1;
if(r < 0 || r > 3 || c < 0 || c > 3) continue;
A[r][c] ^= 1;
}
}
return A;
}
```
2018-02-22 14:47:22 +08:00
# 16. ????-???
2018-02-13 22:59:02 +08:00
```java
private Set<String> paths;
private List<Integer> curPath;
public int countPath(int[][] map, int n, int m) {
paths = new HashSet<>();
curPath = new ArrayList<>();
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (map[i][j] == 1) {
map[i][j] = -1;
int[][] leftRightDirection = {{1, 0}, {-1, 0}};
int[][] topDownDirection = {{0, 1}, {0, -1}};
for (int[] lr : leftRightDirection) {
for (int[] td : topDownDirection) {
int[][] directions = {lr, td};
backtracking(map, n, m, i, j, directions);
}
}
return paths.size();
}
}
}
return 0;
}
private void backtracking(int[][] map, int n, int m, int r, int c, int[][] directions) {
if (map[r][c] == 2) {
String path = "";
for (int num : curPath) {
path += num;
}
paths.add(path);
return;
}
for (int i = 0; i < directions.length; i++) {
int nextR = r + directions[i][0];
int nextC = c + directions[i][1];
if (nextR < 0 || nextR >= n || nextC < 0 || nextC >= m || map[nextR][nextC] == -1) continue;
map[nextR][nextC] = map[nextR][nextC] == 2 ? 2 : -1;
curPath.add(nextR);
curPath.add(nextC);
backtracking(map, n, m, nextR, nextC, directions);
curPath.remove(curPath.size() - 1);
curPath.remove(curPath.size() - 1);
map[nextR][nextC] = map[nextR][nextC] == 2 ? 2 : 0;
}
}
```
2018-02-22 14:47:22 +08:00
# 17. ????-????????????
2018-02-13 22:59:02 +08:00
```java
public int countArea(int[] A, int n) {
int max = 0;
for (int i = 0; i < n; i++) {
int min = A[i];
for (int j = i; j < n; j++) {
min = Math.min(min, A[j]);
max = Math.max(max, min * (j - i + 1));
}
}
return max;
}
```
2018-02-22 14:47:22 +08:00
# 18. ????-?????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
?????????<3F><><EFBFBD><EFBFBD>????????????????????? 26 ?????????????????????????????????????????????<3F><>??????? "ac" ?? "abc"????????????? "ac" > "abc"???????????????????????? "abc" ????<3F><>???????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????????????????????????? s1 ??????? s2 ?????????<3F><>????????? s1 ???????????? 'a' ????????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
???????????????s1 ?? s2 ????? len<sub>i</sub> ?????????????????? i ??????????? 'aaa' ?? 'bbb' ??????? 2 ?????? 'aa' ?? 'bb' ????????????????????????<3F><>????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
????????????? len1 ???????????????????????????????????? i ???????????????
2018-02-13 22:59:02 +08:00
```java
String s1 = in.next();
String s2 = in.next();
int len1 = in.nextInt();
int len2 = in.nextInt();
int len = Math.min(s2.length(), len2);
int[] subtractArr = new int[len];
for (int i = 0; i < len; i++) {
char c1 = i < s1.length() ? s1.charAt(i) : 'a';
char c2 = s2.charAt(i);
subtractArr[i] = c2 - c1;
}
int ret = 0;
for (int i = len1; i <= len; i++) {
for (int j = 0; j < i; j++) {
ret += subtractArr[j] * Math.pow(26, i - j - 1);
}
}
System.out.println(ret - 1);
```
2018-02-22 14:47:22 +08:00
# 19. ????-???????
2018-02-13 22:59:02 +08:00
```java
int W = in.nextInt();
double Y = in.nextDouble();
double x = in.nextDouble();
int N = in.nextInt();
while (N-- > 0) {
2018-02-22 14:47:22 +08:00
Y++; // ??????????????? 1
2018-02-13 22:59:02 +08:00
Y += (21 - Y) * x;
}
System.out.println((int) Math.ceil(Y));
```
2018-02-22 14:47:22 +08:00
# 20. ???-?????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
??????????????????????????????
2018-02-13 22:59:02 +08:00
```java
int n = in.nextInt();
int t = in.nextInt();
int c = in.nextInt();
int[] values = new int[n];
for (int i = 0; i < n; i++) {
values[i] = in.nextInt();
}
int cnt = 0;
int totalValue = 0;
for (int s = 0, e = c - 1; e < n; s++, e++) {
if (s == 0) {
for (int j = 0; j < c; j++) totalValue += values[j];
} else {
totalValue = totalValue - values[s - 1] + values[e];
}
if (totalValue <= t) cnt++;
}
System.out.println(cnt);
```
2018-02-22 14:47:22 +08:00
# 22. ???-?<3F><>??????
2018-02-13 22:59:02 +08:00
```java
int n = in.nextInt();
int minX, minY, maxX, maxY;
minX = minY = Integer.MAX_VALUE;
maxX = maxY = Integer.MIN_VALUE;
for (int i = 0; i < n; i++) {
int x = in.nextInt();
int y = in.nextInt();
minX = Math.min(minX, x);
minY = Math.min(minY, y);
maxX = Math.max(maxX, x);
maxY = Math.max(maxY, y);
}
System.out.println((int) Math.pow(Math.max(maxX - minX, maxY - minY), 2));
```
2018-02-22 14:47:22 +08:00
# 23. ???-???????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
P ( ?????????? ) = 1 - P ( ?????????? )
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
?????????????????????????<3F><>??<3F><>??????????????? in.nextDouble()??
2018-02-13 22:59:02 +08:00
```java
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while (in.hasNext()) {
int n = in.nextInt();
int m = in.nextInt();
int x = in.nextInt();
int y = in.nextInt();
int t = in.nextInt();
2018-02-22 14:47:22 +08:00
in.nextLine(); // ??
2018-02-13 22:59:02 +08:00
double pcc = 0.0;
double sum = 0.0;
for (int i = 1; i <= n; i++) {
2018-02-22 14:47:22 +08:00
String[] token = in.nextLine().split(" "); // ??
2018-02-13 22:59:02 +08:00
for (int j = 1; j <= m; j++) {
double p = Double.parseDouble(token[j - 1]);
// double p = in.nextDouble();
sum += p;
if (i == x && j == y) {
pcc = p;
}
}
}
double pss = sum / (n * m);
pcc = computePOfIRT(pcc, t);
pss = computePOfIRT(pss, t);
System.out.println(pcc > pss ? "cc" : pss > pcc ? "ss" : "equal");
System.out.printf("%.2f\n", Math.max(pcc, pss));
}
}
// compute probability of independent repeated trials
private static double computePOfIRT(double p, int t) {
return 1 - Math.pow((1 - p), t);
}
```
2018-02-22 14:47:22 +08:00
# 24. ???-?????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
?????????????????? DP??
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
dp[i][j] ??????? (i,j) <20><>?<3F><>?????????????????? N\*M ??????? i == N || j == M????? (i,j) ???????????????????????????????????????
2018-02-13 22:59:02 +08:00
2018-02-22 14:47:22 +08:00
??????????????<3F><>? 3 ?<3F><>?? 3 ?????????????????????????<3F><>????????????????????
2018-02-13 22:59:02 +08:00
```java
int N = in.nextInt();
int M = in.nextInt();
int K = in.nextInt();
boolean[][] mushroom = new boolean[N][M];
while (K-- > 0) {
int x = in.nextInt();
int y = in.nextInt();
mushroom[x - 1][y - 1] = true;
}
double[][] dp = new double[N][M];
dp[0][0] = 1;
for (int i = 0; i < N; i++) {
for (int j = 0; j < M; j++) {
if (mushroom[i][j]) dp[i][j] = 0;
else {
double cur = dp[i][j];
if (i == N - 1 && j == M - 1) break;
if (i == N - 1) dp[i][j + 1] += cur;
else if (j == M - 1) dp[i + 1][j] += cur;
else {
dp[i][j + 1] += cur / 2;
dp[i + 1][j] += cur / 2;
}
}
}
}
System.out.printf("%.2f\n", dp[N - 1][M - 1]);
```