关注
等我提交的时候,没时间了。。。 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]);
}
}
查看原帖
点赞 评论
相关推荐
点赞 评论 收藏
分享
04-15 18:54
卫生部北京老年医学研究所 前端工程师 点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 职场捅娄子大赛 #
292201次浏览 2783人参与
# 晒一下我的毕业照 #
20580次浏览 153人参与
# 华泰证券Fintech星战营 #
163777次浏览 185人参与
# 华为求职进展汇总 #
4619269次浏览 28141人参与
# 好好告别我的学生时代 #
10394次浏览 195人参与
# 一人一个landing小技巧 #
52462次浏览 857人参与
# 机械人,签完三方你在忙什么? #
47944次浏览 211人参与
# 简历无回复,你会继续海投还是优化再投? #
66806次浏览 690人参与
# 产品人专业大盘点 #
45263次浏览 293人参与
# 如何KTV领导 #
54572次浏览 409人参与
# 运营来爆料 #
42493次浏览 319人参与
# 互联网行业现在还值得去吗 #
16134次浏览 53人参与
# 你的秋招第一面感觉怎么样 #
69303次浏览 554人参与
# 嵌入式岗知多少 #
38524次浏览 424人参与
# 秋招最大的收获是什么? #
31633次浏览 287人参与
# 来聊聊机械薪资天花板是哪家 #
121373次浏览 735人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
84637次浏览 647人参与
# 记录实习开销 #
9419次浏览 67人参与
# 如果不工作真的会快乐吗 #
115687次浏览 941人参与
# 应届生应该先就业还是先择业 #
105382次浏览 623人参与
# 节后第一天上班,我的精神状态 #
8502次浏览 72人参与