Commit b1619211 by 张敏捷

add 2020 阿里

parent 329c989c
import java.util.ArrayList;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Scanner;
public class First {
public static int dfs(HashMap<Integer, List<Integer>> map, int start, boolean[] memo) {
List<Integer> temp = map.get(start);
memo[start] = true;
int res = temp.size();
for (Integer admire : temp) {
if (start < admire && !memo[admire])
res += dfs(map, admire, memo);
}
memo[start] = false;
return res;
}
/**
* 这道题的意思是 给定一个数组 这个数组里面的元素是从1开始的
* 这个数组满足一个规则 其下标越小 那么这个数组的这个元素的能力越大
* 当只有这个元素的能力比另一个元素大的时候 这个元素才能够被后面的元素投票
* 问题:
* 给定一个数组 这个数组里面的元素表示
* 当前这个下标的人可以自己投票 或者给自己的下标所指的
* 人投票的人投票
* 如果这个元素是0 那么他只能给自己投票
* 针对这个数组的每一个下标 输出他能够被投票的最大值
* 例如
* 输入
* 4
* 0 1 1 1
* 输出
* 4 (后面三位都都仰慕1号位的人 因此都投给他投的人 也就是自己)
* 1
* 1
* 1
*/
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
int[] admires = new int[n + 1];
for (int i = 1; i <= n; i++) {
admires[i] = scanner.nextInt();
}
HashMap<Integer, List<Integer>> map = new HashMap<>();
for (int i = 1; i < admires.length; i++) {
if (!map.containsKey(i)) {
map.put(i, new ArrayList<>());
}
if (admires[i] != 0 && admires[i] != i) {
if (!map.containsKey(admires[i])) {
map.put(admires[i], new ArrayList<>());
}
List<Integer> temp = map.get(admires[i]);
temp.add(i);
}
}
System.out.println(map);
for (int i = 1; i <= n; i++) {
System.out.println(dfs(map, i, new boolean[n + 1]) + 1);
}
}
}
package com.company;
package com.company;
import java.util.*;
public class Second {
static class Pair {
public Integer key;
public Integer value;
public Pair(Integer key, Integer value) {
this.key = key;
this.value = value;
}
}
public static int resolve(HashMap<Integer, List<Pair>> map, int start, int end, int size) {
boolean[] memo = new boolean[size];
return dfs(map, start, end, memo, 0);
}
public static int dfs(HashMap<Integer, List<Pair>> map, int start, int end, boolean[] memo, int current) {
if (start == end) return current;
memo[start] = true;
List<Pair> temp = map.get(start);
int res = Integer.MAX_VALUE;
for (Pair tempPair : temp) {
if (!memo[tempPair.key]) {
res = Math.min(res, dfs(map, tempPair.key, end, memo, current + tempPair.value));
}
}
memo[start] = false;
return res;
}
/**
* 这道题是说
* 给定 n 个城市(下标从1开始)和 m 条城市间的路径 以及一个目标城市 x (n种的下标)
* 接下来输入 m 行 表示 这个 m 条路径的 起始点 a 终止点 b 和 路程消费的时间 l
* 为 每个城市中都有一个人 需要到目标城市 x
* 而且每个人都会选择最短的路径
* 那么 这 n 个人选择的路径中 路径消费最长时间的是多少
*/
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt(), m = scanner.nextInt(), x = scanner.nextInt();
HashMap<Integer, List<Pair>> map = new HashMap<>();
for (int i = 0; i < m; i++) {
int a = scanner.nextInt(), b = scanner.nextInt(), l = scanner.nextInt();
if (!map.containsKey(a)) {
map.put(a, new ArrayList<>());
}
List<Pair> temp = map.get(a);
temp.add(new Pair(b, l));
}
int res = Integer.MIN_VALUE;
for (int i = 1; i <= n; i++) {
res = Math.max(res, resolve(map, i, x, n + 1) + resolve(map, x, i, n + 1));
}
System.out.println(res);
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment