Submission #395782

#TimeUsernameProblemLanguageResultExecution timeMemory
395782peuchHorses (IOI15_horses)C++17
17 / 100
616 ms33660 KiB
#include "horses.h" #include<bits/stdc++.h> using namespace std; const int MAXN = 5e5 + 10; const long long MOD = 1e9 + 7; int n; int x[MAXN], y[MAXN]; long long segX[4 * MAXN], segY[4 * MAXN], segV[4 * MAXN]; long long merge(int pos, int e, int d); void buildY(int pos, int ini, int fim); void buildX(int pos, int ini, int fim); void buildV(int pos, int ini, int fim); long long queryX(int pos, int ini, int fim, int p, int q); long long queryV(int pos, int ini, int fim, int p, int q); void upY(int pos, int ini, int fim, int id); void upX(int pos, int ini, int fim, int id); void upV(int pos, int ini, int fim, int id); int init(int N, int X[], int Y[]) { n = N; for(int i = 1; i <= n; i++) x[i] = X[i - 1], y[i] = Y[i - 1]; buildX(1, 1, n); buildV(1, 1, n); buildY(1, 1, n); return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD; } long long merge(int e, int d){ long long aux = queryX(1, 1, n, e + 1, d); if(aux * y[d] >= y[e]) return d; else return e; } void buildY(int pos, int ini, int fim){ if(ini == fim){ segY[pos] = ini; return; } int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; buildY(e, ini, mid); buildY(d, mid + 1, fim); segY[pos] = merge(segY[e], segY[d]); } void buildX(int pos, int ini, int fim){ if(ini == fim){ segX[pos] = x[ini]; return; } int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; buildX(e, ini, mid); buildX(d, mid + 1, fim); segX[pos] = min(MOD, segX[e] * segX[d]); } void buildV(int pos, int ini, int fim){ if(ini == fim){ segV[pos] = x[ini]; return; } int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; buildV(e, ini, mid); buildV(d, mid + 1, fim); segV[pos] = (segV[e] * segV[d]) % MOD; } long long queryX(int pos, int ini, int fim, int p, int q){ if(ini > q || fim < p) return 1; if(ini >= p && fim <= q) return segX[pos]; int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; return min(queryX(e, ini, mid, p, q) * queryX(d, mid + 1, fim, p, q), MOD); } long long queryV(int pos, int ini, int fim, int p, int q){ if(ini > q || fim < p) return 1; if(ini >= p && fim <= q) return segV[pos]; int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; return (queryV(e, ini, mid, p, q) * queryV(d, mid + 1, fim, p, q)) % MOD; } void upY(int pos, int ini, int fim, int id){ if(ini > id || fim < id) return; if(ini == fim) return; int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; upY(e, ini, mid, id); upY(d, mid + 1, fim, id); segY[pos] = merge(segY[e], segY[d]); } void upX(int pos, int ini, int fim, int id){ if(ini > id || fim < id) return; if(ini == fim) {segX[pos] = x[id]; return;} int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; upX(e, ini, mid, id); upX(d, mid + 1, fim, id); segX[pos] = min(MOD, segX[e] * segX[d]); } void upV(int pos, int ini, int fim, int id){ if(ini > id || fim < id) return; if(ini == fim) {segV[pos] = x[id]; return;} int mid = (ini + fim) >> 1, e = pos << 1, d = e | 1; upV(e, ini, mid, id); upV(d, mid + 1, fim, id); segV[pos] = (segV[e] * segV[d]) % MOD; } int updateY(int pos, int val){ y[pos] = val; upY(1, 1, n, pos); return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD; } int updateX(int pos, int val){ x[pos] = val; upX(1, 1, n, pos); upV(1, 1, n, pos); return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD; }

Compilation message (stderr)

horses.cpp: In function 'int init(int, int*, int*)':
horses.cpp:30:48: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   30 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |                                          ~~~~~~^
horses.cpp:30:52: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   30 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~
horses.cpp: In function 'void buildY(int, int, int)':
horses.cpp:47:26: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   47 |  segY[pos] = merge(segY[e], segY[d]);
      |                    ~~~~~~^
horses.cpp:47:35: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   47 |  segY[pos] = merge(segY[e], segY[d]);
      |                             ~~~~~~^
horses.cpp: In function 'void upY(int, int, int, int)':
horses.cpp:92:26: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   92 |  segY[pos] = merge(segY[e], segY[d]);
      |                    ~~~~~~^
horses.cpp:92:35: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
   92 |  segY[pos] = merge(segY[e], segY[d]);
      |                             ~~~~~~^
horses.cpp: In function 'int updateY(int, int)':
horses.cpp:116:48: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
  116 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |                                          ~~~~~~^
horses.cpp:116:52: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
  116 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~
horses.cpp: In function 'int updateX(int, int)':
horses.cpp:123:48: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
  123 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |                                          ~~~~~~^
horses.cpp:123:52: warning: conversion from 'long long int' to 'int' may change value [-Wconversion]
  123 |  return (y[segY[1]] * queryV(1, 1, n, 1, segY[1])) % MOD;
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~
#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...