안녕하세요 저는 Facebook 해커 경연 대회에 참가했으며이 질문에 대한 해결책을 얻었습니다. 나는 O (K^2)의 순서로 문제를 풀었지만이 사람은 O (^ K)에서 그것을 풀었다. 코드가하는 일을 설명해주세요.map [(int) x] ++는 무엇입니까?
import java.io.File;
import java.util.Scanner;
public class FindTheMin {
private long getNextMin(long[] map, long start, long k) {
while (map[(int)(start)] > 0)
start++;
return start;
}
public long findNth(long n, long k, long a, long b, long c, long r) {
long[] cache = new long[100010];
long[] map = new long[100010];
long pre = a;
for (int i = 0; i < k; i++) {
long num;
if (i == 0)
num = a;
else
num = (b * pre + c) % r;
cache[i] = num;
if (num <= k + 1)
map[(int) num]++;
pre = num;
}
pre = getNextMin(map, 0, k);
cache[(int)k] = pre;
map[(int)pre]++;
for (int i = 0; i <= (int)k; i++) {
long deque = cache[i];
if (deque > k) {
long x = getNextMin(map, pre, k);
cache[i] = x;
map[(int)x]++;
pre = x;
} else {
if (deque < pre) {
if(map[(int)deque] == 1) {
cache[i] = deque;
pre = deque;
continue;
}
}
map[(int)deque]--;
long x = getNextMin(map, pre, k);
cache[i] = x;
pre = x;
map[(int)x]++;
}
}
return cache[(int)((n - 1) % (k + 1))];
}
public static void main(String[] args) {
try {
Scanner s = new Scanner(new File("in.txt"));
int m = s.nextInt();
FindTheMin f = new FindTheMin();
for (int i = 1; i <= m; i++) {
int n, k, a, b, c, r;
n = s.nextInt();
k = s.nextInt();
a = s.nextInt();
b = s.nextInt();
c = s.nextInt();
r = s.nextInt();
System.out.println("Case #" + i + ": " + f.findNth(n, k, a, b, c, r));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
그리고 이런 것들을 배우는 가장 좋은 방법은 무엇입니까? 자바를 배우는 가장 좋은 방법은? 이 질문 https://www.facebook.com/hackercup/problems.php?pid=494433657264959&round=185564241586420
** O (^ K) **는 무엇을 의미합니까? – MrSmith42
[c] 태그가 붙은 이유는 무엇입니까? – AnT
facebook 계정이없는 것을 선호하는 사람들을 위해 질문을 올리시겠습니까? – dasblinkenlight