关注
等我提交的时候,没时间了。。。 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]);
}
}
查看原帖
点赞 评论
相关推荐
10-11 16:54
河北工程技术学院 测试工程师 点赞 评论 收藏
分享
11-20 10:43
门头沟学院 嵌入式软件开发 点赞 评论 收藏
分享
牛客热帖
正在热议
# 25届秋招总结 #
501620次浏览 5138人参与
# 职场情商大赛 #
10334次浏览 128人参与
# 晒一晒我的offer #
10115586次浏览 107064人参与
# 字节跳动工作体验 #
227849次浏览 3134人参与
# 我的求职思考 #
4266676次浏览 57591人参与
# 运营人的第一份offer应该如何选 #
88712次浏览 891人参与
# 如何排解工作中的焦虑 #
80880次浏览 1106人参与
# 夸夸我的求职搭子 #
135478次浏览 1397人参与
# 机械人的薪资开到多少,才适合去? #
79337次浏览 377人参与
# 滴!实习打卡 #
497609次浏览 5656人参与
# 百度工作体验 #
149340次浏览 1512人参与
# 我的岗位说明书 #
97309次浏览 961人参与
# 面试题刺客退退退 #
147918次浏览 2184人参与
# 如果不工作真的会快乐吗 #
62557次浏览 542人参与
# 我的第一份实习怎么找的 #
36561次浏览 317人参与
# 25届非技术实习投递记录 #
97219次浏览 878人参与
# 小红书求职进展汇总 #
32232次浏览 273人参与
# 求职你最看重什么? #
19286次浏览 136人参与
# 远程面试的尴尬瞬间 #
24173次浏览 324人参与
# 你投了多少份简历了? #
71795次浏览 843人参与