关注
等我提交的时候,没时间了。。。 import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String line = scanner.nextLine();
int n = Integer.parseInt(line);
int[][] area = new int[n][n];
for (int i = 0; i < n; i++) {
line = scanner.nextLine();
String[] split = line.split(",");
if (split.length != n) {
throw new IllegalArgumentException("错误输入");
}
int j = 0;
for (String num : split) {
area[i][j++] = Integer.parseInt(num);
}
}
int minimumTimeCost = getMinimumTimeCost(n, area);
System.out.println(minimumTimeCost);
}
private static int getMinimumTimeCost(int n, int[][] area) {
int res = Integer.MAX_VALUE;
for (int i = 0; i < n; i++) {
int t = dfs(area, 0, i, n, 0);
// System.out.println("res:" + t);
if (t < res && t != -1)
res = t;
}
return res;
}
static int dfs(int[][] area, int i, int j, int n, int t) {
// System.out.println(i + " " + j);
if (i > n || j >= n)
return -1;
if (i == n)
return t;
if (j == n - 1)
return dfs(area, i += 2, j, n, t += area[i - 1][j]);
if (area[i + 1][j] <= area[i][j + 1])
return dfs(area, i += 2, j, n, t += area[i - 1][j]);
return dfs(area, i, j += 2, n, t += area[i][j - 1]);
}
}
查看原帖
点赞 评论
相关推荐
牛客热帖
正在热议
# 25届秋招总结 #
485819次浏览 4957人参与
# 晒一晒我的offer #
10075141次浏览 106689人参与
# 职场情商大赛 #
4907次浏览 75人参与
# 我在牛爱网找对象 #
79094次浏览 589人参与
# 如何排解工作中的焦虑 #
77665次浏览 1083人参与
# lastday知无不言 #
25377次浏览 185人参与
# 联影求职进展汇总 #
21803次浏览 190人参与
# 机械人怎么评价今年的华为 #
161620次浏览 1374人参与
# 哪个瞬间让你对大厂祛魅了? #
114453次浏览 688人参与
# 夸夸我的求职搭子 #
134583次浏览 1382人参与
# 你觉得今年秋招难吗 #
1263739次浏览 15840人参与
# 同bg的你秋招战况如何? #
99078次浏览 746人参与
# 我发现了面试通关密码 #
951707次浏览 15841人参与
# 实习,投递多份简历没人回复怎么办 #
2479351次浏览 35041人参与
# 非技术岗简历怎么写 #
163811次浏览 2502人参与
# 校招入职后的感受 #
164395次浏览 1997人参与
# 怎么面对正在吵架的两个同事 #
10608次浏览 79人参与
# 找工作时遇到的神仙HR #
572766次浏览 3917人参与
# 非技术er求职现状 #
26180次浏览 223人参与
# 今年形式下双非本找得到工作吗 #
54137次浏览 500人参与