제출 #1119075

#제출 시각아이디문제언어결과실행 시간메모리
1119075secretwood01Self Study (JOI22_ho_t2)Java
0 / 100
426 ms40252 KiB
import java.util.*; import java.io.*; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); PrintWriter pw = new PrintWriter(System.out); StringTokenizer st = new StringTokenizer(br.readLine()); int N = Integer.parseInt(st.nextToken()); long M = Long.parseLong(st.nextToken()); long [] a, b; a = new long[N]; b = new long[N]; st = new StringTokenizer(br.readLine()); StringTokenizer st1 = new StringTokenizer(br.readLine()); for (int i=0;i<N;i++) { a[i] = Long.parseLong(st.nextToken()); b[i] = Long.parseLong(st1.nextToken()); } pw.println(bs(a, b, N, M)); pw.close(); br.close(); } public static boolean f(long [] a, long [] b, int N, long M, long mid) { long ans = 0; for (int i=0;i<a.length;i++) { if (a[i]>b[i]) { long nC = Math.min(M, (mid+a[i]-1)/a[i]); ans+=nC; long remain = mid-nC*a[i]; if (remain>0) { ans+=(remain+b[i]-1)/b[i]; } } else { ans+=(mid+b[i]-1)/b[i]; } } return ans<=N*M; } public static long bs(long [] a, long [] b, int N, long M) { long lo = 0; long hi = (long)Math.pow(10,18); while (lo<hi) { long mid = (lo+hi+1)/2; if (f(a, b, N, M, mid)) { lo = mid; } else { hi = mid-1; } } return lo; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...