QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#444058 | #8527. Power Divisions | ucup-team133# | AC ✓ | 1555ms | 66904kb | C++17 | 24.0kb | 2024-06-15 17:11:20 | 2024-06-15 17:11:20 |
Judging History
answer
#include <iostream>
#include <vector>
#include <string>
#include <map>
#include <set>
#include <queue>
#include <algorithm>
#include <cmath>
#include <iomanip>
#include <random>
#include <stdio.h>
#include <fstream>
#include <functional>
#include <cassert>
#include <unordered_map>
#include <bitset>
#include <chrono>
#include <utility>
namespace atcoder {
namespace internal {
// @param m `1 <= m`
// @return x mod m
constexpr long long safe_mod(long long x, long long m) {
x %= m;
if (x < 0) x += m;
return x;
}
// Fast modular multiplication by barrett reduction
// Reference: https://en.wikipedia.org/wiki/Barrett_reduction
// NOTE: reconsider after Ice Lake
struct barrett {
unsigned int _m;
unsigned long long im;
// @param m `1 <= m < 2^31`
barrett(unsigned int m) : _m(m), im((unsigned long long)(-1) / m + 1) {}
// @return m
unsigned int umod() const { return _m; }
// @param a `0 <= a < m`
// @param b `0 <= b < m`
// @return `a * b % m`
unsigned int mul(unsigned int a, unsigned int b) const {
// [1] m = 1
// a = b = im = 0, so okay
// [2] m >= 2
// im = ceil(2^64 / m)
// -> im * m = 2^64 + r (0 <= r < m)
// let z = a*b = c*m + d (0 <= c, d < m)
// a*b * im = (c*m + d) * im = c*(im*m) + d*im = c*2^64 + c*r + d*im
// c*r + d*im < m * m + m * im < m * m + 2^64 + m <= 2^64 + m * (m + 1) < 2^64 * 2
// ((ab * im) >> 64) == c or c + 1
unsigned long long z = a;
z *= b;
#ifdef _MSC_VER
unsigned long long x;
_umul128(z, im, &x);
#else
unsigned long long x =
(unsigned long long)(((unsigned __int128)(z)*im) >> 64);
#endif
unsigned int v = (unsigned int)(z - x * _m);
if (_m <= v) v += _m;
return v;
}
};
// @param n `0 <= n`
// @param m `1 <= m`
// @return `(x ** n) % m`
constexpr long long pow_mod_constexpr(long long x, long long n, int m) {
if (m == 1) return 0;
unsigned int _m = (unsigned int)(m);
unsigned long long r = 1;
unsigned long long y = safe_mod(x, m);
while (n) {
if (n & 1) r = (r * y) % _m;
y = (y * y) % _m;
n >>= 1;
}
return r;
}
// Reference:
// M. Forisek and J. Jancina,
// Fast Primality Testing for Integers That Fit into a Machine Word
// @param n `0 <= n`
constexpr bool is_prime_constexpr(int n) {
if (n <= 1) return false;
if (n == 2 || n == 7 || n == 61) return true;
if (n % 2 == 0) return false;
long long d = n - 1;
while (d % 2 == 0) d /= 2;
constexpr long long bases[3] = {2, 7, 61};
for (long long a : bases) {
long long t = d;
long long y = pow_mod_constexpr(a, t, n);
while (t != n - 1 && y != 1 && y != n - 1) {
y = y * y % n;
t <<= 1;
}
if (y != n - 1 && t % 2 == 0) {
return false;
}
}
return true;
}
template <int n> constexpr bool is_prime = is_prime_constexpr(n);
// @param b `1 <= b`
// @return pair(g, x) s.t. g = gcd(a, b), xa = g (mod b), 0 <= x < b/g
constexpr std::pair<long long, long long> inv_gcd(long long a, long long b) {
a = safe_mod(a, b);
if (a == 0) return {b, 0};
// Contracts:
// [1] s - m0 * a = 0 (mod b)
// [2] t - m1 * a = 0 (mod b)
// [3] s * |m1| + t * |m0| <= b
long long s = b, t = a;
long long m0 = 0, m1 = 1;
while (t) {
long long u = s / t;
s -= t * u;
m0 -= m1 * u; // |m1 * u| <= |m1| * s <= b
// [3]:
// (s - t * u) * |m1| + t * |m0 - m1 * u|
// <= s * |m1| - t * u * |m1| + t * (|m0| + |m1| * u)
// = s * |m1| + t * |m0| <= b
auto tmp = s;
s = t;
t = tmp;
tmp = m0;
m0 = m1;
m1 = tmp;
}
// by [3]: |m0| <= b/g
// by g != b: |m0| < b/g
if (m0 < 0) m0 += b / s;
return {s, m0};
}
// Compile time primitive root
// @param m must be prime
// @return primitive root (and minimum in now)
constexpr int primitive_root_constexpr(int m) {
if (m == 2) return 1;
if (m == 167772161) return 3;
if (m == 469762049) return 3;
if (m == 754974721) return 11;
if (m == 998244353) return 3;
int divs[20] = {};
divs[0] = 2;
int cnt = 1;
int x = (m - 1) / 2;
while (x % 2 == 0) x /= 2;
for (int i = 3; (long long)(i)*i <= x; i += 2) {
if (x % i == 0) {
divs[cnt++] = i;
while (x % i == 0) {
x /= i;
}
}
}
if (x > 1) {
divs[cnt++] = x;
}
for (int g = 2;; g++) {
bool ok = true;
for (int i = 0; i < cnt; i++) {
if (pow_mod_constexpr(g, (m - 1) / divs[i], m) == 1) {
ok = false;
break;
}
}
if (ok) return g;
}
}
template <int m> constexpr int primitive_root = primitive_root_constexpr(m);
} // namespace internal
} // namespace atcoder
#include <cassert>
#include <numeric>
#include <type_traits>
namespace atcoder {
namespace internal {
#ifndef _MSC_VER
template <class T>
using is_signed_int128 =
typename std::conditional<std::is_same<T, __int128_t>::value ||
std::is_same<T, __int128>::value,
std::true_type,
std::false_type>::type;
template <class T>
using is_unsigned_int128 =
typename std::conditional<std::is_same<T, __uint128_t>::value ||
std::is_same<T, unsigned __int128>::value,
std::true_type,
std::false_type>::type;
template <class T>
using make_unsigned_int128 =
typename std::conditional<std::is_same<T, __int128_t>::value,
__uint128_t,
unsigned __int128>;
template <class T>
using is_integral = typename std::conditional<std::is_integral<T>::value ||
is_signed_int128<T>::value ||
is_unsigned_int128<T>::value,
std::true_type,
std::false_type>::type;
template <class T>
using is_signed_int = typename std::conditional<(is_integral<T>::value &&
std::is_signed<T>::value) ||
is_signed_int128<T>::value,
std::true_type,
std::false_type>::type;
template <class T>
using is_unsigned_int =
typename std::conditional<(is_integral<T>::value &&
std::is_unsigned<T>::value) ||
is_unsigned_int128<T>::value,
std::true_type,
std::false_type>::type;
template <class T>
using to_unsigned = typename std::conditional<
is_signed_int128<T>::value,
make_unsigned_int128<T>,
typename std::conditional<std::is_signed<T>::value,
std::make_unsigned<T>,
std::common_type<T>>::type>::type;
#else
template <class T> using is_integral = typename std::is_integral<T>;
template <class T>
using is_signed_int =
typename std::conditional<is_integral<T>::value && std::is_signed<T>::value,
std::true_type,
std::false_type>::type;
template <class T>
using is_unsigned_int =
typename std::conditional<is_integral<T>::value &&
std::is_unsigned<T>::value,
std::true_type,
std::false_type>::type;
template <class T>
using to_unsigned = typename std::conditional<is_signed_int<T>::value,
std::make_unsigned<T>,
std::common_type<T>>::type;
#endif
template <class T>
using is_signed_int_t = std::enable_if_t<is_signed_int<T>::value>;
template <class T>
using is_unsigned_int_t = std::enable_if_t<is_unsigned_int<T>::value>;
template <class T> using to_unsigned_t = typename to_unsigned<T>::type;
} // namespace internal
} // namespace atcoder
#include <cassert>
#include <numeric>
#include <type_traits>
#ifdef _MSC_VER
#include <intrin.h>
#endif
namespace atcoder {
namespace internal {
struct modint_base {};
struct static_modint_base : modint_base {};
template <class T> using is_modint = std::is_base_of<modint_base, T>;
template <class T> using is_modint_t = std::enable_if_t<is_modint<T>::value>;
} // namespace internal
template <int m, std::enable_if_t<(1 <= m)>* = nullptr>
struct static_modint : internal::static_modint_base {
using mint = static_modint;
public:
static constexpr int mod() { return m; }
static mint raw(int v) {
mint x;
x._v = v;
return x;
}
static_modint() : _v(0) {}
template <class T, internal::is_signed_int_t<T>* = nullptr>
static_modint(T v) {
long long x = (long long)(v % (long long)(umod()));
if (x < 0) x += umod();
_v = (unsigned int)(x);
}
template <class T, internal::is_unsigned_int_t<T>* = nullptr>
static_modint(T v) {
_v = (unsigned int)(v % umod());
}
static_modint(bool v) { _v = ((unsigned int)(v) % umod()); }
unsigned int val() const { return _v; }
mint& operator++() {
_v++;
if (_v == umod()) _v = 0;
return *this;
}
mint& operator--() {
if (_v == 0) _v = umod();
_v--;
return *this;
}
mint operator++(int) {
mint result = *this;
++*this;
return result;
}
mint operator--(int) {
mint result = *this;
--*this;
return result;
}
mint& operator+=(const mint& rhs) {
_v += rhs._v;
if (_v >= umod()) _v -= umod();
return *this;
}
mint& operator-=(const mint& rhs) {
_v -= rhs._v;
if (_v >= umod()) _v += umod();
return *this;
}
mint& operator*=(const mint& rhs) {
unsigned long long z = _v;
z *= rhs._v;
_v = (unsigned int)(z % umod());
return *this;
}
mint& operator/=(const mint& rhs) { return *this = *this * rhs.inv(); }
mint operator+() const { return *this; }
mint operator-() const { return mint() - *this; }
mint pow(long long n) const {
assert(0 <= n);
mint x = *this, r = 1;
while (n) {
if (n & 1) r *= x;
x *= x;
n >>= 1;
}
return r;
}
mint inv() const {
if (prime) {
assert(_v);
return pow(umod() - 2);
} else {
auto eg = internal::inv_gcd(_v, m);
assert(eg.first == 1);
return eg.second;
}
}
friend mint operator+(const mint& lhs, const mint& rhs) {
return mint(lhs) += rhs;
}
friend mint operator-(const mint& lhs, const mint& rhs) {
return mint(lhs) -= rhs;
}
friend mint operator*(const mint& lhs, const mint& rhs) {
return mint(lhs) *= rhs;
}
friend mint operator/(const mint& lhs, const mint& rhs) {
return mint(lhs) /= rhs;
}
friend bool operator==(const mint& lhs, const mint& rhs) {
return lhs._v == rhs._v;
}
friend bool operator!=(const mint& lhs, const mint& rhs) {
return lhs._v != rhs._v;
}
private:
unsigned int _v;
static constexpr unsigned int umod() { return m; }
static constexpr bool prime = internal::is_prime<m>;
};
template <int id> struct dynamic_modint : internal::modint_base {
using mint = dynamic_modint;
public:
static int mod() { return (int)(bt.umod()); }
static void set_mod(int m) {
assert(1 <= m);
bt = internal::barrett(m);
}
static mint raw(int v) {
mint x;
x._v = v;
return x;
}
dynamic_modint() : _v(0) {}
template <class T, internal::is_signed_int_t<T>* = nullptr>
dynamic_modint(T v) {
long long x = (long long)(v % (long long)(mod()));
if (x < 0) x += mod();
_v = (unsigned int)(x);
}
template <class T, internal::is_unsigned_int_t<T>* = nullptr>
dynamic_modint(T v) {
_v = (unsigned int)(v % mod());
}
dynamic_modint(bool v) { _v = ((unsigned int)(v) % mod()); }
unsigned int val() const { return _v; }
mint& operator++() {
_v++;
if (_v == umod()) _v = 0;
return *this;
}
mint& operator--() {
if (_v == 0) _v = umod();
_v--;
return *this;
}
mint operator++(int) {
mint result = *this;
++*this;
return result;
}
mint operator--(int) {
mint result = *this;
--*this;
return result;
}
mint& operator+=(const mint& rhs) {
_v += rhs._v;
if (_v >= umod()) _v -= umod();
return *this;
}
mint& operator-=(const mint& rhs) {
_v += mod() - rhs._v;
if (_v >= umod()) _v -= umod();
return *this;
}
mint& operator*=(const mint& rhs) {
_v = bt.mul(_v, rhs._v);
return *this;
}
mint& operator/=(const mint& rhs) { return *this = *this * rhs.inv(); }
mint operator+() const { return *this; }
mint operator-() const { return mint() - *this; }
mint pow(long long n) const {
assert(0 <= n);
mint x = *this, r = 1;
while (n) {
if (n & 1) r *= x;
x *= x;
n >>= 1;
}
return r;
}
mint inv() const {
auto eg = internal::inv_gcd(_v, mod());
assert(eg.first == 1);
return eg.second;
}
friend mint operator+(const mint& lhs, const mint& rhs) {
return mint(lhs) += rhs;
}
friend mint operator-(const mint& lhs, const mint& rhs) {
return mint(lhs) -= rhs;
}
friend mint operator*(const mint& lhs, const mint& rhs) {
return mint(lhs) *= rhs;
}
friend mint operator/(const mint& lhs, const mint& rhs) {
return mint(lhs) /= rhs;
}
friend bool operator==(const mint& lhs, const mint& rhs) {
return lhs._v == rhs._v;
}
friend bool operator!=(const mint& lhs, const mint& rhs) {
return lhs._v != rhs._v;
}
private:
unsigned int _v;
static internal::barrett bt;
static unsigned int umod() { return bt.umod(); }
};
template <int id> internal::barrett dynamic_modint<id>::bt = 998244353;
using modint998244353 = static_modint<998244353>;
using modint1000000007 = static_modint<1000000007>;
using modint = dynamic_modint<-1>;
namespace internal {
template <class T>
using is_static_modint = std::is_base_of<internal::static_modint_base, T>;
template <class T>
using is_static_modint_t = std::enable_if_t<is_static_modint<T>::value>;
template <class> struct is_dynamic_modint : public std::false_type {};
template <int id>
struct is_dynamic_modint<dynamic_modint<id>> : public std::true_type {};
template <class T>
using is_dynamic_modint_t = std::enable_if_t<is_dynamic_modint<T>::value>;
} // namespace internal
} // namespace atcoder
using namespace std;
using namespace atcoder;
using mint = modint1000000007;
#define rep(i,n) for (int i=0;i<n;i+=1)
#define rrep(i,n) for (int i=n-1;i>-1;i--)
#define pb push_back
#define all(x) (x).begin(), (x).end()
#define debug(x) cerr << #x << " = " << (x) << " (L" << __LINE__ << " )\n";
template<class T>
using vec = vector<T>;
template<class T>
using vvec = vec<vec<T>>;
template<class T>
using vvvec = vec<vvec<T>>;
using ll = long long;
using pii = pair<int,int>;
using pll = pair<ll,ll>;
template<class T>
bool chmin(T &a, T b){
if (a>b){
a = b;
return true;
}
return false;
}
template<class T>
bool chmax(T &a, T b){
if (a<b){
a = b;
return true;
}
return false;
}
template<class T>
T sum(vec<T> x){
T res=0;
for (auto e:x){
res += e;
}
return res;
}
template<class T>
void printv(vec<T> x){
for (auto e:x){
cout<<e<<" ";
}
cout<<endl;
}
template<class T,class U>
ostream& operator<<(ostream& os, const pair<T,U>& A){
os << "(" << A.first <<", " << A.second << ")";
return os;
}
template<class T>
ostream& operator<<(ostream& os, const set<T>& S){
os << "set{";
for (auto a:S){
os << a;
auto it = S.find(a);
it++;
if (it!=S.end()){
os << ", ";
}
}
os << "}";
return os;
}
template<class T>
ostream& operator<<(ostream& os, const tuple<T,T,T>& a){
auto [x,y,z] = a;
os << "(" << x << ", " << y << ", " << z << ")";
return os;
}
template<class T>
ostream& operator<<(ostream& os, const map<ll,T>& A){
os << "map{";
for (auto e:A){
os << e.first;
os << ":";
os << e.second;
os << ", ";
}
os << "}";
return os;
}
template<class T>
ostream& operator<<(ostream& os, const vec<T>& A){
os << "[";
rep(i,A.size()){
os << A[i];
if (i!=A.size()-1){
os << ", ";
}
}
os << "]" ;
return os;
}
ostream& operator<<(ostream& os, const mint& a){
os << a.val();
return os;
}
const int K = 1e6 + 100;
void solve(){
int N;
cin>>N;
vec<int> A(N);
rep(i,N){
cin>>A[i];
}
vec<mint> dp(N+1,0);
dp[0] = 1;
int64_t seed = chrono::duration_cast<chrono::milliseconds>(chrono::system_clock::now().time_since_epoch()).count();
mt19937_64 rnd(seed);
uniform_int_distribution<ll> dist_x(0, (1ll<<60)-1);
vec<ll> bit_hash(K),bit_hash_cum(K+1,0);
rep(i,K){
bit_hash[i] = dist_x(rnd);
bit_hash_cum[i+1] = bit_hash_cum[i] ^ bit_hash[i];
}
rep(i,K){
bit_hash_cum[i+1] = bit_hash_cum[i] ^ bit_hash[i];
}
vec<int> tmp_bit(K,0);
auto calc_dc = [&](auto self,int L,int R)->void {
if (R-L==1) return ;
int mid = (L+R)>>1;
self(self,L,mid);
/*
dp[l]->dp[r] (L <= l < mid <= r < R) の寄与を考える
A[l:r] = A[l:mid] + A[mid:r] の総和が2冪である
A[mid:r]の総和が例えば0101110110001とするとA[l:mid]は
0110001001110 or 0110001001110(1が1個以上) であることが必要十分
->A[mid:r]の総和を2進数で持った値をxとし、yを先頭の1を1個だけ残すように削除して得られる値をyとしたとき、
x=1010001001110 or y = 10100010011101が必要十分であり、これらは排反
x,yについてはzobrist_hashを用いて判定する
xは単に各桁の値を持っていればいい
yについては hash(x) ^ (l桁目~r桁目のhash)みたいになるのでhighestbitの区間を持ちたい
繰り上がりごとに計算できるか?→できる
right側はlowestbitも必要
*/
int lowest_bit;
pair<int,int> highest_bit_range;
ll tmp_zobrist_hash;
vec<int> touch_bit = {};
map<ll,mint> x_map,y_map;
lowest_bit = A[mid-1];
highest_bit_range = {A[mid-1],A[mid-1]};
tmp_zobrist_hash = bit_hash[A[mid-1]];
tmp_bit[A[mid-1]] = 1;
touch_bit.push_back(A[mid-1]);
x_map[tmp_zobrist_hash] = dp[mid-1];
y_map[tmp_zobrist_hash] = dp[mid-1];
auto add_left_bit = [&](int a){
if (lowest_bit == -1){
lowest_bit = a;
highest_bit_range = {a,a};
tmp_zobrist_hash ^= bit_hash[a];
tmp_bit[a] = 1;
touch_bit.push_back(a);
return ;
}
for (int i=a;i<K;i++){
touch_bit.push_back(i);
if (!tmp_bit[i]){
chmin(lowest_bit,i);
if (highest_bit_range.first == i + 1){
highest_bit_range = {i,highest_bit_range.second};
while (highest_bit_range.first!=0 && tmp_bit[highest_bit_range.first-1]){
highest_bit_range.first--;
}
}
else if (highest_bit_range.second == i-1){
highest_bit_range = {highest_bit_range.first,i};
}
else if (highest_bit_range.second < i-1){
highest_bit_range = {i,i};
}
tmp_zobrist_hash ^= bit_hash[i];
tmp_bit[i] = 1;
break;
}
if (lowest_bit == i){
lowest_bit = i + 1;
}
if (highest_bit_range.first == i){
highest_bit_range = {i+1,max(highest_bit_range.second,i+1)};
}
else if (highest_bit_range.second == i){
highest_bit_range = {i+1,i+1};
}
tmp_zobrist_hash ^= bit_hash[i];
tmp_bit[i] = 0;
}
};
auto init_all = [&](){
for (auto i:touch_bit){
tmp_bit[i] = 0;
}
lowest_bit = -1;
highest_bit_range = {-1,-1};
tmp_zobrist_hash = 0;
touch_bit = {};
};
mint add_first = dp[mid-1];
for (int i=mid-2;L<=i;i--){
add_left_bit(A[i]);
//debug(lowest_bit);
//debug(highest_bit_range);
//debug(vec<int>({tmp_bit.begin(),tmp_bit.begin()+10}));
x_map[tmp_zobrist_hash] += dp[i];
auto [l,r] = highest_bit_range;
y_map[tmp_zobrist_hash ^ bit_hash_cum[r+1] ^ bit_hash_cum[l+1]] += dp[i];
if (tmp_zobrist_hash == bit_hash[r]){
add_first += dp[i];
}
}
init_all();
dp[mid] += add_first;
lowest_bit = A[mid];
highest_bit_range = {A[mid],A[mid]};
tmp_zobrist_hash = bit_hash[A[mid]];
tmp_bit[A[mid]] = 1;
touch_bit = {A[mid]};
for (int i = mid+1;i < R;i++){
auto [l,r] = highest_bit_range;
ll check = tmp_zobrist_hash ^ bit_hash_cum[l+1] ^ bit_hash_cum[r+1];
ll check_flip = bit_hash_cum[l+1] ^ check;
ll x_match = check_flip ^ bit_hash_cum[lowest_bit+1] , y_match = x_match ^ bit_hash[highest_bit_range.second + 1];
//debug(make_pair(i,tmp_zobrist_hash));
//debug(x_match);
//debug(y_match);
//debug(x_map);
//debug(y_map);
if (tmp_zobrist_hash != bit_hash[lowest_bit]){
if (x_map.count(x_match)){
dp[i] += x_map[x_match];
}
if (y_map.count(y_match)){
dp[i] += y_map[y_match];
}
}
else{
if (y_map.count(tmp_zobrist_hash)){
dp[i] += y_map[tmp_zobrist_hash];
}
}
if (i!=N){
add_left_bit(A[i]);
}
}
init_all();
self(self,mid,R);
};
calc_dc(calc_dc,0,N+1);
//debug(dp);
cout << dp[N].val() << "\n";
}
int main(){
ios::sync_with_stdio(false);
std::cin.tie(nullptr);
cout << fixed << setprecision(15);
int T = 1;
while (T--){
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 3ms
memory: 22816kb
input:
5 2 0 0 1 1
output:
6
result:
ok 1 number(s): "6"
Test #2:
score: 0
Accepted
time: 9ms
memory: 22732kb
input:
1 0
output:
1
result:
ok 1 number(s): "1"
Test #3:
score: 0
Accepted
time: 3ms
memory: 22708kb
input:
2 1 1
output:
2
result:
ok 1 number(s): "2"
Test #4:
score: 0
Accepted
time: 3ms
memory: 22704kb
input:
3 2 1 1
output:
3
result:
ok 1 number(s): "3"
Test #5:
score: 0
Accepted
time: 4ms
memory: 22788kb
input:
4 3 2 2 3
output:
4
result:
ok 1 number(s): "4"
Test #6:
score: 0
Accepted
time: 4ms
memory: 22648kb
input:
5 3 4 4 2 4
output:
2
result:
ok 1 number(s): "2"
Test #7:
score: 0
Accepted
time: 4ms
memory: 22708kb
input:
7 3 4 3 5 6 3 4
output:
6
result:
ok 1 number(s): "6"
Test #8:
score: 0
Accepted
time: 10ms
memory: 22704kb
input:
10 8 6 5 6 7 8 6 8 9 9
output:
4
result:
ok 1 number(s): "4"
Test #9:
score: 0
Accepted
time: 4ms
memory: 22656kb
input:
96 5 1 0 2 5 5 2 4 2 4 4 2 3 4 0 2 1 4 3 1 2 0 2 2 3 2 4 5 3 5 2 0 2 2 5 3 0 4 5 3 5 4 4 3 1 2 0 5 4 5 0 2 3 2 4 0 0 4 2 0 2 5 3 3 1 5 5 1 1 1 0 5 0 3 0 2 1 1 0 5 0 3 3 4 4 5 3 0 2 2 0 5 4 5 0 5
output:
11332014
result:
ok 1 number(s): "11332014"
Test #10:
score: 0
Accepted
time: 7ms
memory: 22656kb
input:
480 2 0 4 4 1 0 0 3 1 1 4 2 5 5 4 2 1 2 4 4 1 3 4 3 0 5 2 0 2 5 1 0 5 0 0 5 5 0 2 5 2 2 3 1 4 3 5 4 5 2 4 4 4 4 1 4 0 3 4 3 4 1 0 4 3 4 5 4 3 5 0 2 2 0 1 5 4 4 2 0 3 3 3 4 3 0 5 5 3 1 5 1 0 1 0 4 3 0 5 1 4 1 4 3 0 1 3 5 0 3 3 1 0 4 1 1 2 0 1 2 0 3 5 2 0 5 5 5 5 3 5 1 0 2 5 2 2 0 2 0 2 3 5 1 2 1 5 4 ...
output:
506782981
result:
ok 1 number(s): "506782981"
Test #11:
score: 0
Accepted
time: 3ms
memory: 23232kb
input:
2400 0 2 2 0 5 4 3 2 3 2 5 4 5 4 4 5 2 2 4 2 2 0 1 0 5 0 4 4 0 0 5 0 4 0 1 3 4 5 0 3 1 0 4 0 2 5 0 3 3 3 3 1 0 5 5 3 1 3 5 2 4 0 5 0 4 5 4 2 2 1 5 2 2 4 1 0 5 1 5 0 1 2 0 0 3 5 4 0 0 1 1 1 4 2 0 5 1 3 3 5 0 4 4 1 5 5 3 4 4 4 0 2 4 0 5 1 3 1 5 0 5 5 1 3 0 3 1 2 0 1 1 3 5 2 3 4 0 3 0 5 4 0 4 3 5 0 5 2...
output:
586570528
result:
ok 1 number(s): "586570528"
Test #12:
score: 0
Accepted
time: 37ms
memory: 24596kb
input:
12000 2 2 1 2 0 2 5 3 2 0 1 3 2 5 4 0 0 5 3 2 0 2 3 4 3 2 1 4 3 0 3 5 4 1 0 2 4 1 3 2 3 5 0 3 0 0 4 0 4 5 1 0 4 1 1 1 5 4 3 0 3 5 4 5 2 5 0 1 2 3 5 5 2 5 4 2 0 4 4 3 0 0 2 5 0 3 4 2 5 4 2 1 4 5 1 1 2 3 0 3 3 3 3 4 0 5 3 4 0 3 0 2 0 0 2 0 3 4 2 2 0 1 0 5 3 0 2 0 2 2 1 0 5 3 5 4 5 5 0 4 0 4 1 4 4 3 2 ...
output:
201653965
result:
ok 1 number(s): "201653965"
Test #13:
score: 0
Accepted
time: 185ms
memory: 30968kb
input:
60000 2 5 0 3 2 3 5 3 5 5 4 1 1 5 3 0 1 1 2 5 5 5 0 3 2 0 3 2 3 3 0 0 1 4 3 1 4 2 3 3 0 5 1 0 1 1 5 5 4 0 5 4 1 3 1 3 5 3 2 4 4 4 5 4 3 2 3 2 4 5 2 0 4 5 1 2 0 4 0 5 1 3 4 1 2 4 1 1 3 3 0 1 1 3 0 0 2 3 3 2 1 4 1 2 4 3 3 5 2 5 3 4 3 0 2 1 1 1 5 1 2 4 2 3 1 2 1 0 2 0 1 1 5 5 3 4 2 5 2 4 5 3 0 5 1 4 2 ...
output:
592751350
result:
ok 1 number(s): "592751350"
Test #14:
score: 0
Accepted
time: 1446ms
memory: 65720kb
input:
300000 0 5 1 5 5 4 5 3 0 5 0 5 1 4 1 2 2 2 3 0 1 5 4 0 3 1 4 5 2 1 0 3 2 1 2 5 0 2 4 5 0 1 2 1 1 0 0 5 3 0 0 3 4 5 0 2 1 1 1 2 5 1 4 3 1 0 2 0 0 4 3 3 2 5 3 3 1 5 2 0 2 4 3 1 0 3 4 1 3 3 1 0 0 1 1 1 3 1 2 3 5 3 3 2 0 3 0 0 5 5 0 0 0 0 1 4 3 3 4 3 4 5 3 3 5 1 1 4 2 2 1 3 2 1 1 0 0 5 5 0 0 3 2 4 5 5 2...
output:
842503795
result:
ok 1 number(s): "842503795"
Test #15:
score: 0
Accepted
time: 1230ms
memory: 58600kb
input:
300000 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0...
output:
432100269
result:
ok 1 number(s): "432100269"
Test #16:
score: 0
Accepted
time: 1252ms
memory: 58576kb
input:
300000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 10000...
output:
432100269
result:
ok 1 number(s): "432100269"
Test #17:
score: 0
Accepted
time: 1451ms
memory: 60696kb
input:
299995 1 1 0 0 0 1 0 0 1 1 0 1 0 1 0 0 1 1 0 0 1 1 1 0 1 1 0 0 1 0 0 1 1 0 1 0 1 0 0 1 1 1 1 1 1 1 1 1 0 0 0 0 1 1 1 1 1 1 0 0 1 0 1 1 1 0 0 1 1 0 1 0 1 1 0 1 0 1 0 1 0 1 1 0 1 0 0 0 0 0 0 1 0 1 1 0 1 1 1 1 0 1 1 1 1 0 0 0 0 0 1 0 1 1 0 0 0 1 0 0 1 1 0 0 1 1 1 1 1 1 0 1 1 0 0 1 0 0 1 0 1 0 1 1 0 0 0...
output:
261818019
result:
ok 1 number(s): "261818019"
Test #18:
score: 0
Accepted
time: 1472ms
memory: 66452kb
input:
299997 2 2 0 9 4 4 2 3 8 9 3 9 1 6 4 0 1 5 1 0 7 9 3 3 8 9 3 8 3 6 9 3 9 5 9 1 4 4 7 5 9 0 7 3 7 2 0 3 3 8 2 1 7 6 8 1 6 1 8 4 7 6 3 6 1 6 8 9 3 8 1 5 0 8 1 10 0 3 4 5 8 5 6 9 2 4 5 0 9 0 9 5 1 0 3 7 5 8 8 10 10 3 3 10 5 8 9 9 7 4 4 1 1 6 5 7 2 5 8 3 3 9 6 4 1 0 2 6 2 8 7 7 10 5 7 8 3 8 5 1 6 6 6 1 ...
output:
999738318
result:
ok 1 number(s): "999738318"
Test #19:
score: 0
Accepted
time: 1448ms
memory: 66820kb
input:
299999 97 34 33 30 15 73 31 69 60 63 79 87 78 13 49 58 23 38 91 28 70 70 14 98 56 59 81 66 29 21 10 51 94 32 41 98 16 48 67 62 55 5 17 81 30 91 39 93 73 74 46 74 41 99 19 10 0 16 72 95 84 40 97 17 76 10 42 50 66 97 4 30 71 74 46 5 75 87 55 82 38 94 14 82 49 10 23 21 19 99 52 100 71 29 64 73 54 88 2 ...
output:
799664563
result:
ok 1 number(s): "799664563"
Test #20:
score: 0
Accepted
time: 1514ms
memory: 66904kb
input:
299997 97 181 693 569 34 770 725 1 82 951 965 962 962 532 803 824 669 686 529 339 434 430 439 478 553 354 443 632 725 139 56 709 797 847 617 100 837 94 80 527 644 861 8 455 710 599 473 818 685 886 645 722 239 634 450 16 825 337 156 708 827 790 462 716 67 557 535 466 820 465 567 140 633 112 85 691 16...
output:
152812109
result:
ok 1 number(s): "152812109"
Test #21:
score: 0
Accepted
time: 1433ms
memory: 65372kb
input:
300000 7938 3542 362 8246 5914 9327 9031 9802 6879 5983 1052 8554 8571 187 3412 4806 1991 9465 7940 8741 5792 7136 6654 7716 2896 4212 3357 6278 3398 5631 4759 6295 7385 5487 699 3015 422 4849 4933 3169 3194 7014 7605 9619 8126 4673 5020 842 9477 2925 857 1263 3326 729 4638 3383 7716 887 7821 2009 7...
output:
294967268
result:
ok 1 number(s): "294967268"
Test #22:
score: 0
Accepted
time: 1496ms
memory: 64784kb
input:
300000 68003 20603 19535 98755 78166 31928 28492 76831 77102 95079 32154 12348 91482 11514 67510 4208 30189 31364 77353 60045 60124 58954 32468 38599 70247 18763 32984 76656 86646 79971 63986 68195 33578 90458 79520 92707 17642 7744 26043 12273 28374 63264 97058 36502 6212 70591 51401 76682 41512 18...
output:
32
result:
ok 1 number(s): "32"
Test #23:
score: 0
Accepted
time: 1555ms
memory: 64608kb
input:
299995 704135 597658 946639 146393 887400 976091 33440 872707 692148 819088 785763 285388 604527 830260 851525 558807 997790 380755 251183 328941 129356 741341 530638 817968 603319 899844 731899 356842 867124 825330 645685 373685 70290 726706 995759 161401 398693 132928 535725 831104 643517 149954 7...
output:
1
result:
ok 1 number(s): "1"
Test #24:
score: 0
Accepted
time: 1463ms
memory: 65424kb
input:
300000 999990 999988 999987 999987 999989 999988 999987 999987 999988 999988 999988 999988 999987 999987 999987 999987 999989 999989 999988 999988 999987 999987 999987 999987 999991 999989 999987 999987 999988 999988 999986 999986 999986 999986 999986 999986 999987 999987 999987 999985 999985 999985...
output:
907456874
result:
ok 1 number(s): "907456874"
Test #25:
score: 0
Accepted
time: 1242ms
memory: 59936kb
input:
299998 1000000 999998 999997 999994 999993 999992 999990 999987 999986 999985 999984 999983 999981 999977 999976 999975 999974 999971 999969 999968 999966 999964 999963 999961 999960 999955 999953 999947 999946 999945 999944 999943 999940 999937 999936 999935 999934 999933 999930 999928 999927 99992...
output:
299998
result:
ok 1 number(s): "299998"
Test #26:
score: 0
Accepted
time: 1290ms
memory: 60716kb
input:
300000 225118 225117 225116 225114 225114 225112 225111 225110 225108 225108 225105 225105 225105 225103 225103 225099 225099 225095 225094 225093 225091 225091 225091 225089 225089 225089 225088 225086 225086 225086 225084 225083 225081 225080 225077 225075 225075 225074 225073 225072 225071 225068...
output:
651536657
result:
ok 1 number(s): "651536657"
Test #27:
score: 0
Accepted
time: 1371ms
memory: 62072kb
input:
300000 966603 966600 966600 966599 966596 966591 966588 966586 966586 966585 966583 966581 966580 966577 966577 966578 966578 966577 966576 966576 966581 966580 966580 966583 966583 966586 966589 966590 966592 966593 966592 966590 966588 966587 966585 966584 966581 966580 966578 966577 966577 966573...
output:
956228402
result:
ok 1 number(s): "956228402"
Test #28:
score: 0
Accepted
time: 1376ms
memory: 63132kb
input:
300000 318513 318509 318504 318503 318499 318498 318496 318496 318490 318490 318487 318486 318482 318480 318480 318479 318478 318477 318477 318480 318483 318482 318479 318479 318478 318478 318475 318474 318472 318471 318470 318469 318467 318465 318461 318459 318457 318456 318450 318450 318450 318448...
output:
505865071
result:
ok 1 number(s): "505865071"
Test #29:
score: 0
Accepted
time: 1429ms
memory: 66004kb
input:
299999 814266 814266 814265 814263 814262 814262 814264 814266 814265 814263 814263 814259 814258 814256 814256 814253 814251 814251 814249 814249 814248 814247 814246 814245 814244 814243 814243 814249 814250 814247 814247 814247 814241 814239 814236 814229 814229 814230 814229 814226 814226 814225...
output:
586808369
result:
ok 1 number(s): "586808369"
Test #30:
score: 0
Accepted
time: 1434ms
memory: 66524kb
input:
299997 999997 999994 999993 999993 999995 999993 999992 999989 999989 999990 999991 999994 999992 999992 999992 999990 999986 999984 999984 999982 999981 999978 999978 999979 999980 999982 999981 999981 999982 999982 999983 999986 999982 999981 999981 999983 999984 999985 999986 999986 999987 999989...
output:
215177543
result:
ok 1 number(s): "215177543"
Test #31:
score: 0
Accepted
time: 1459ms
memory: 66792kb
input:
300000 999997 999995 999995 999996 999997 999996 999996 999994 999994 999995 999995 999991 999990 999989 999988 999988 999992 999992 999991 999988 999987 999987 999985 999985 999986 999987 999987 999987 999990 999994 999994 999992 999992 999993 999995 999995 999992 999992 999993 999994 999993 999993...
output:
777454227
result:
ok 1 number(s): "777454227"
Test #32:
score: 0
Accepted
time: 1445ms
memory: 66748kb
input:
299996 999994 999992 999990 999986 999984 999983 999983 999984 999984 999983 999982 999981 999981 999984 999982 999981 999981 999983 999982 999980 999980 999981 999983 999982 999979 999979 999980 999981 999983 999984 999985 999986 999986 999987 999986 999986 999983 999983 999984 999985 999986 999988...
output:
682333830
result:
ok 1 number(s): "682333830"
Test #33:
score: 0
Accepted
time: 1437ms
memory: 65880kb
input:
300000 39 38 38 36 35 35 32 32 33 29 29 28 28 28 27 24 24 25 25 25 28 26 20 20 19 19 20 21 19 19 18 18 19 23 23 23 24 22 22 22 22 26 26 22 22 22 22 23 23 24 24 26 25 24 23 23 24 24 24 24 28 25 24 24 26 27 28 29 25 25 26 27 28 28 28 30 30 26 24 24 22 22 22 22 24 27 28 28 24 22 20 17 17 18 19 21 23 25...
output:
794828803
result:
ok 1 number(s): "794828803"
Test #34:
score: 0
Accepted
time: 1214ms
memory: 58756kb
input:
299996 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700 679700...
output:
253642571
result:
ok 1 number(s): "253642571"
Test #35:
score: 0
Accepted
time: 1237ms
memory: 59612kb
input:
300000 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015 341015...
output:
871111475
result:
ok 1 number(s): "871111475"
Test #36:
score: 0
Accepted
time: 1266ms
memory: 60052kb
input:
299998 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696 47696...
output:
216182855
result:
ok 1 number(s): "216182855"
Test #37:
score: 0
Accepted
time: 1322ms
memory: 60564kb
input:
300000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 10000...
output:
647909995
result:
ok 1 number(s): "647909995"
Test #38:
score: 0
Accepted
time: 1297ms
memory: 60896kb
input:
300000 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995 999995...
output:
891450574
result:
ok 1 number(s): "891450574"
Test #39:
score: 0
Accepted
time: 1328ms
memory: 62192kb
input:
300000 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997 999997...
output:
10337043
result:
ok 1 number(s): "10337043"
Test #40:
score: 0
Accepted
time: 1339ms
memory: 63240kb
input:
299999 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 15 16 16...
output:
106078597
result:
ok 1 number(s): "106078597"
Test #41:
score: 0
Accepted
time: 1431ms
memory: 65244kb
input:
300000 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925682 925682 925682 925682 925682 925682 925682 925682 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681 925681...
output:
722322244
result:
ok 1 number(s): "722322244"
Test #42:
score: 0
Accepted
time: 1455ms
memory: 65664kb
input:
299997 862127 862126 862126 862126 862126 862125 862125 862125 862125 862125 862125 862124 862124 862124 862124 862125 862125 862126 862125 862125 862123 862123 862123 862123 862123 862123 862124 862123 862123 862123 862123 862123 862123 862123 862123 862124 862124 862123 862123 862123 862123 862125...
output:
721299215
result:
ok 1 number(s): "721299215"
Test #43:
score: 0
Accepted
time: 1259ms
memory: 63664kb
input:
299995 51927 51926 51925 51923 51922 51918 51917 51916 51913 51910 51909 51906 51904 51903 51902 51901 51900 51895 51888 51887 51883 51882 51880 51878 51875 51872 51870 51869 51865 51864 51862 51861 51859 51853 51852 51846 51845 51844 51842 51839 51838 51836 51832 51830 51825 51821 51820 51819 51818...
output:
66848417
result:
ok 1 number(s): "66848417"
Test #44:
score: 0
Accepted
time: 1380ms
memory: 64752kb
input:
299995 150532 150531 150528 150527 150525 150524 150522 150519 150516 150514 150513 150509 150508 150507 150506 150502 150501 150500 150499 150498 150494 150492 150491 150490 150488 150487 150486 150484 150482 150480 150479 150478 150476 150475 150471 150466 150463 150461 150460 150459 150458 150457...
output:
385634475
result:
ok 1 number(s): "385634475"
Test #45:
score: 0
Accepted
time: 1354ms
memory: 64860kb
input:
299995 240071 240069 240067 240066 240065 240064 240062 240061 240060 240056 240053 240052 240049 240045 240044 240042 240040 240039 240038 240037 240036 240034 240032 240028 240025 240024 240022 240018 240016 240014 240011 240008 240007 240004 239999 239998 239997 239996 239994 239993 239990 239989...
output:
664763392
result:
ok 1 number(s): "664763392"
Test #46:
score: 0
Accepted
time: 1434ms
memory: 65072kb
input:
299995 772825 839854 839854 839855 824089 824087 824086 824083 824082 824081 824080 824080 824083 824082 824081 824074 824074 824075 824075 824075 824077 824078 824079 824078 824077 824073 824070 824069 824069 824067 824067 824064 824063 824063 824064 824063 824061 824061 824062 824065 824064 824063...
output:
37411958
result:
ok 1 number(s): "37411958"
Test #47:
score: 0
Accepted
time: 1418ms
memory: 66160kb
input:
300000 1000000 999995 999995 999996 999997 999996 999996 999995 999993 999993 999992 999992 999991 999991 999991 999991 999996 999992 999991 999990 999990 999992 999991 999990 999987 999984 999984 999984 999982 999980 999980 999979 999979 999980 999979 999979 999980 999980 999979 999979 999979 99997...
output:
450879006
result:
ok 1 number(s): "450879006"
Test #48:
score: 0
Accepted
time: 1480ms
memory: 66592kb
input:
299996 58 58 58 58 60 58 55 55 56 49 48 48 47 47 48 49 51 50 48 46 43 42 42 44 45 47 49 50 50 53 53 53 54 51 50 50 52 53 55 54 53 51 51 51 51 58 57 54 51 51 51 51 52 51 50 47 46 43 43 43 43 45 47 46 43 40 39 38 38 41 41 41 38 38 35 35 36 35 35 35 34 34 36 34 34 35 36 33 30 29 28 27 26 23 20 20 18 18...
output:
298459941
result:
ok 1 number(s): "298459941"
Test #49:
score: 0
Accepted
time: 1499ms
memory: 66424kb
input:
299996 999998 999997 999995 999995 999995 999993 999993 999993 999990 999990 999990 999990 999990 999989 999987 999986 999986 999988 999989 999988 999988 999990 999997 999994 999990 999989 999989 999988 999987 999987 999988 999986 999986 999987 999988 999979 999977 999974 999971 999970 999970 999970...
output:
490613738
result:
ok 1 number(s): "490613738"
Test #50:
score: 0
Accepted
time: 1479ms
memory: 66456kb
input:
300000 999997 999996 999993 999993 999994 999995 999996 999996 999996 999996 999999 999998 999998 999998 999997 999996 999996 999996 999996 999997 999997 999997 999999 1000000 486 486 487 479 469 466 466 467 468 467 467 468 468 468 467 467 468 466 463 463 463 461 459 459 456 453 452 447 447 448 449 ...
output:
395820026
result:
ok 1 number(s): "395820026"
Test #51:
score: 0
Accepted
time: 1492ms
memory: 66652kb
input:
299997 290494 290494 290489 290487 290487 290488 290488 290486 290483 290483 290483 290481 290481 290482 290485 290487 290488 290486 290484 290484 290485 290487 290490 290490 290491 290487 290481 290481 290482 290483 290484 290485 290484 290484 290483 290483 290482 290480 290479 290479 290481 290480...
output:
935739706
result:
ok 1 number(s): "935739706"
Test #52:
score: 0
Accepted
time: 1533ms
memory: 66424kb
input:
299997 1000000 999997 999997 999997 999997 999998 999997 999997 1 1 2 0 0 1 2 994988 994986 994986 994987 994986 994984 994984 994985 994985 994985 994986 994985 994985 994984 994984 994983 994983 994983 994983 994987 994988 994988 994988 994988 994985 994985 994986 994985 994985 994986 994984 99498...
output:
894523307
result:
ok 1 number(s): "894523307"
Test #53:
score: 0
Accepted
time: 1481ms
memory: 66464kb
input:
299995 985715 985715 985716 985714 985713 985713 985715 985715 985715 985716 985716 985715 985715 985716 985719 985714 985714 985715 985715 985715 985717 985715 985715 985716 985715 985714 985714 985715 985715 985718 985714 985712 985712 985713 985713 985712 985712 985714 985713 985712 985712 985714...
output:
773526751
result:
ok 1 number(s): "773526751"
Test #54:
score: 0
Accepted
time: 1450ms
memory: 66464kb
input:
299995 673443 673440 673440 673441 673439 673437 673437 673438 673440 673440 673440 673442 673441 673441 673442 673442 673442 673439 673439 673440 673437 673437 673437 673435 673435 673436 673439 673439 673439 673441 673438 673437 673437 673438 673438 673440 673440 673440 673440 673440 673443 673440...
output:
168543508
result:
ok 1 number(s): "168543508"
Test #55:
score: 0
Accepted
time: 1299ms
memory: 63008kb
input:
299999 1000000 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...
output:
554899496
result:
ok 1 number(s): "554899496"
Test #56:
score: 0
Accepted
time: 1334ms
memory: 63892kb
input:
299998 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 10000...
output:
677216579
result:
ok 1 number(s): "677216579"
Test #57:
score: 0
Accepted
time: 1354ms
memory: 63872kb
input:
299998 598714 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 100000...
output:
558726013
result:
ok 1 number(s): "558726013"
Test #58:
score: 0
Accepted
time: 1363ms
memory: 62308kb
input:
300000 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490436 490434 490434 490434 490434 490434 490434 490434 490434 490434 490434...
output:
211401824
result:
ok 1 number(s): "211401824"
Test #59:
score: 0
Accepted
time: 1432ms
memory: 64404kb
input:
299997 834526 834522 834522 834522 834522 834523 834523 834524 834524 834525 834525 834525 834525 834528 986989 986989 986990 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 100000...
output:
316134807
result:
ok 1 number(s): "316134807"
Test #60:
score: 0
Accepted
time: 1404ms
memory: 65112kb
input:
300000 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598 931598...
output:
820369394
result:
ok 1 number(s): "820369394"
Test #61:
score: 0
Accepted
time: 1419ms
memory: 63672kb
input:
299999 619766 619765 619763 619763 619764 619763 619763 619764 619765 619765 619765 619768 619765 619765 619766 619766 619766 619767 619765 619763 619763 619764 619764 619764 619763 619763 619763 619763 151290 151290 151290 151290 151290 151290 151290 151290 151290 151290 151290 151290 151290 151290...
output:
480415349
result:
ok 1 number(s): "480415349"
Test #62:
score: 0
Accepted
time: 1449ms
memory: 65392kb
input:
299997 9 9 9 9 9 9 9 9 9 9 9 9 8 8 8 8 9 9 8 8 8 8 8 8 8 8 9 9 8 8 8 8 8 8 8 8 8 8 8 8 7 7 7 7 7 7 7 7 8 8 7 7 7 7 10 10 10 10 11 10 10 9 9 10 9 9 9 9 10 10 10 10 9 9 9 9 9 9 9 9 9 9 8 8 8 8 9 9 9 9 10 10 10 10 10 10 10 10 12 11 11 11 11 11 11 9 9 9 9 9 9 9 9 11 10 10 9 9 9 9 9 9 9 9 10 9 9 9 9 9 9 ...
output:
471824041
result:
ok 1 number(s): "471824041"
Test #63:
score: 0
Accepted
time: 1417ms
memory: 65764kb
input:
299998 1000000 999999 999998 999998 1000000 999999 999999 999997 999997 999996 999996 999997 999998 999997 999996 999996 999999 999999 999999 999999 1000000 999999 999999 1000000 999997 999997 999996 999996 999997 999998 999997 999996 999996 999999 999999 1000000 5 4 4 2 0 0 1 3 3 2 2 2 2 2 2 4 3 3 ...
output:
675389888
result:
ok 1 number(s): "675389888"
Test #64:
score: 0
Accepted
time: 1483ms
memory: 65900kb
input:
299999 999999 999999 1000000 1000000 999999 999998 999998 999999 999998 999997 999997 1000000 1000000 1000000 999997 999997 999998 999997 999997 999998 999995 999993 999993 999994 999994 999993 999993 999994 999993 999993 999997 999994 999993 999993 999994 999994 999992 999992 999989 999989 999989 9...
output:
591732509
result:
ok 1 number(s): "591732509"
Test #65:
score: 0
Accepted
time: 1488ms
memory: 66444kb
input:
299995 5 4 4 5 5 7 7 7 6 6 6 4 3 2 2 5 6 4 4 5 6 6 3 3 3 3 5 0 0 1 2 3 4 3 3 3 2 1 1 4 4 2 2 2 2 4 2 2 1 1 2 4 4 4 2 0 0 1 1 1 2 4 5 6 6 6 8 7 7 365414 365414 365415 365413 365411 365411 365412 365413 365413 365415 373546 373544 373539 373538 373538 373540 373540 373540 373540 373539 373539 373540 3...
output:
954430198
result:
ok 1 number(s): "954430198"
Test #66:
score: 0
Accepted
time: 1466ms
memory: 66432kb
input:
300000 999999 999998 999998 999999 999999 999994 999993 999993 999994 999994 999996 999996 999996 999996 999996 999996 999996 999996 999995 999995 999996 999996 999995 999995 999995 999995 999992 999992 999992 999992 999994 999994 999994 999993 999993 999994 999994 999993 999993 999998 999997 999997...
output:
324161747
result:
ok 1 number(s): "324161747"
Test #67:
score: 0
Accepted
time: 660ms
memory: 46300kb
input:
300000 1000000 999999 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999985 999984 999983 999982 999981 999980 999979 999978 999977 999976 999975 999974 999973 999972 999971 999970 999969 999968 999967 999966 999965 999964 999963 999962 999961 999960 99995...
output:
300000
result:
ok 1 number(s): "300000"
Test #68:
score: 0
Accepted
time: 1197ms
memory: 64804kb
input:
300000 700002 700002 700003 700004 700005 700006 700007 700008 700009 700010 700011 700012 700013 700014 700015 700016 700017 700018 700019 700020 700021 700022 700023 700024 700025 700026 700027 700028 700029 700030 700031 700032 700033 700034 700035 700036 700037 700038 700039 700040 700041 700042...
output:
300000
result:
ok 1 number(s): "300000"
Test #69:
score: 0
Accepted
time: 1369ms
memory: 62144kb
input:
299998 940318 940318 940308 940308 940304 940302 940302 940302 940300 940300 940300 940300 940304 940302 940302 940300 940300 940298 940294 940292 940292 940292 940286 940286 940284 940282 940282 940282 940282 940284 940284 940286 940288 940286 940284 940284 940284 940278 940274 940272 940272 940270...
output:
43576446
result:
ok 1 number(s): "43576446"
Test #70:
score: 0
Accepted
time: 1471ms
memory: 63948kb
input:
299993 742188 742185 742185 742185 742185 742182 742182 742182 742182 742179 742179 742179 742179 742179 742179 742179 742179 742182 742182 742182 742179 742179 742179 742179 742179 742179 742176 742176 742176 742176 742176 742176 742176 742176 742179 742179 742179 742179 742179 742179 742176 742173...
output:
676440849
result:
ok 1 number(s): "676440849"
Test #71:
score: 0
Accepted
time: 1472ms
memory: 65776kb
input:
299941 1000000 1000000 1000000 999996 999996 999996 999996 999996 999996 999992 999992 999988 999988 999988 999988 999988 999988 999988 999988 999984 999984 999984 999984 999984 999984 999984 999984 999984 999984 999984 999984 999980 999976 999976 999976 999976 999976 999976 999972 999972 999972 999...
output:
970230510
result:
ok 1 number(s): "970230510"
Test #72:
score: 0
Accepted
time: 1501ms
memory: 63744kb
input:
299999 999994 999998 999997 999996 999995 999994 1000000 999999 999998 999998 999995 999998 999997 999996 999995 999996 999998 999997 999996 999999 999999 999996 999997 999998 999999 999996 999995 999998 999997 999996 999995 1000000 999999 999999 999996 999998 999997 999996 999996 999996 999997 9999...
output:
85735841
result:
ok 1 number(s): "85735841"
Test #73:
score: 0
Accepted
time: 1434ms
memory: 64956kb
input:
299999 999986 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999987 999987 999988 999989 999990 999991 999992 999993 999994 999995 999996 999997 999998 999999 999998 999998 999999 999984 999985 999986 999987 999988 999989 999990 999991 999992 999993 999994...
output:
550996080
result:
ok 1 number(s): "550996080"
Test #74:
score: 0
Accepted
time: 1411ms
memory: 65404kb
input:
300000 33 38 37 36 35 34 33 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 5 38 38 23 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 38 37 36 35 34 33 32 31 30 29 28 28 15 40 39 38 37 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16...
output:
964643237
result:
ok 1 number(s): "964643237"
Test #75:
score: 0
Accepted
time: 1399ms
memory: 65844kb
input:
300000 338938 338938 338939 338940 338941 338942 338943 338944 338945 338946 338947 338948 338949 338950 338951 338952 338953 338942 338943 338944 338945 338946 338947 338948 338949 338950 338951 338952 338953 338942 338951 338950 338949 338948 338947 338946 338945 338944 338943 338942 338941 338940...
output:
658149678
result:
ok 1 number(s): "658149678"
Test #76:
score: 0
Accepted
time: 1459ms
memory: 65624kb
input:
300000 713633 713675 713674 713673 713672 713671 713670 713669 713668 713667 713666 713665 713664 713663 713662 713661 713660 713659 713658 713657 713656 713655 713654 713653 713652 713651 713650 713649 713648 713647 713646 713645 713644 713643 713642 713641 713640 713639 713638 713637 713636 713635...
output:
955936919
result:
ok 1 number(s): "955936919"
Test #77:
score: 0
Accepted
time: 1330ms
memory: 66132kb
input:
299999 818023 818024 818025 818026 818027 818028 818029 818030 818031 818032 818033 818034 818035 818036 818037 818038 818039 818040 818041 818042 818043 818044 818045 818046 818047 818048 818049 818050 818051 818052 818053 818054 818055 818056 818057 818058 818059 818060 818061 818062 818063 818064...
output:
181534964
result:
ok 1 number(s): "181534964"
Test #78:
score: 0
Accepted
time: 1277ms
memory: 64588kb
input:
299999 999999 999999 998989 1000000 999999 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999985 999984 999983 999982 999981 999980 999979 999978 999977 999976 999975 999974 999973 999972 999971 999970 999969 999968 999967 999966 999965 999964 999963 99996...
output:
870149621
result:
ok 1 number(s): "870149621"
Test #79:
score: 0
Accepted
time: 1229ms
memory: 63984kb
input:
299999 992607 992608 992609 992610 992611 992612 992613 992614 992615 992616 992617 992618 992619 992620 992621 992622 992623 992624 992625 992626 992627 992628 992629 992630 992631 992632 992633 992634 992635 992636 992637 992638 992639 992640 992641 992642 992643 992644 992645 992646 992647 992648...
output:
875848370
result:
ok 1 number(s): "875848370"
Test #80:
score: 0
Accepted
time: 1188ms
memory: 62804kb
input:
300000 1000000 999999 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999985 999984 999983 999982 999981 999980 999979 999978 999977 999976 999975 999974 999973 999972 999971 999970 999969 999968 999967 999966 999965 999964 999963 999962 999961 999960 99995...
output:
347188675
result:
ok 1 number(s): "347188675"
Test #81:
score: 0
Accepted
time: 1043ms
memory: 55304kb
input:
300000 5450 5450 5451 5452 5453 5454 5455 5456 5457 5458 5459 5460 5461 5462 5463 5464 5465 5466 5467 5468 5469 5470 5471 5472 5473 5474 5475 5476 5477 5478 5479 5480 5481 5482 5483 5484 5485 5486 5487 5488 5489 5490 5491 5492 5493 5494 5495 5496 5497 5498 5499 5500 5501 5502 5503 5504 5505 5506 550...
output:
768008243
result:
ok 1 number(s): "768008243"
Test #82:
score: 0
Accepted
time: 1173ms
memory: 62860kb
input:
300000 262513 262512 262511 262510 262509 262508 262507 262506 262505 262504 262503 262502 262501 262500 262499 262498 262497 262496 262495 262494 262493 262492 262491 262490 262489 262488 262487 262486 262485 262484 262483 262482 262481 262480 262479 262478 262477 262476 262475 262474 262473 262472...
output:
70135250
result:
ok 1 number(s): "70135250"
Test #83:
score: 0
Accepted
time: 1256ms
memory: 64756kb
input:
299999 688771 688772 688773 688774 688775 688776 688777 688778 688779 688780 688781 688782 688783 688784 688785 688786 688787 688788 688789 688790 688791 688792 688793 688794 688795 688796 688797 688798 688799 688800 688801 688802 688803 688804 688805 688806 688807 688808 688809 688810 688811 688812...
output:
954342346
result:
ok 1 number(s): "954342346"
Test #84:
score: 0
Accepted
time: 1300ms
memory: 65636kb
input:
299999 743875 743876 743877 743878 743879 743880 743881 743882 743883 743884 743885 743886 743887 743888 743889 743890 743891 743892 743893 743894 743895 743896 743897 743898 743899 743900 743901 743902 743903 743904 743905 743906 743907 743908 743909 743910 743911 743912 743913 743914 743915 743916...
output:
101196392
result:
ok 1 number(s): "101196392"
Test #85:
score: 0
Accepted
time: 1317ms
memory: 65592kb
input:
299999 992729 992730 992731 992732 992733 992734 992735 992736 992737 992738 992739 992740 992741 992742 992743 992744 992745 992746 992747 992748 992749 992750 992751 992752 992753 992754 992755 992756 992757 992758 992759 992760 992761 992762 992763 992764 992765 992766 992767 992768 992769 992770...
output:
282294193
result:
ok 1 number(s): "282294193"
Test #86:
score: 0
Accepted
time: 1340ms
memory: 66384kb
input:
300000 999087 999088 999089 999090 999091 999092 999093 999094 999095 999096 999097 999098 999099 999100 999101 999102 999103 999104 999105 999106 999107 999108 999109 999110 999111 999112 999113 999114 999115 999116 999117 999118 999119 999120 999121 999122 999123 999124 999125 999126 999127 999128...
output:
45899090
result:
ok 1 number(s): "45899090"
Test #87:
score: 0
Accepted
time: 1420ms
memory: 66424kb
input:
299999 1000000 999999 999998 999997 999996 999995 999994 999993 999992 999991 999990 999989 999988 999987 999986 999985 999984 999983 999982 999981 999980 999979 999978 999977 999976 999975 999974 999973 999972 999971 999970 999969 999968 999967 999966 999965 999964 999963 999962 999961 999960 99995...
output:
14605587
result:
ok 1 number(s): "14605587"
Test #88:
score: 0
Accepted
time: 1461ms
memory: 66068kb
input:
300000 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101...
output:
601340304
result:
ok 1 number(s): "601340304"
Test #89:
score: 0
Accepted
time: 1460ms
memory: 65988kb
input:
300000 675492 675492 675493 675494 675495 675496 675497 675498 675499 675500 675501 675502 675503 675504 675505 675506 675500 675501 675502 675503 675500 675357 675358 675359 675360 675361 675362 675363 675364 675365 675366 675367 675368 675369 675370 675371 675372 675373 675374 675375 675376 675377...
output:
358103300
result:
ok 1 number(s): "358103300"
Test #90:
score: 0
Accepted
time: 1478ms
memory: 64852kb
input:
299999 221586 221585 221584 221583 221582 221581 221580 221580 221588 221587 221586 221585 221584 221583 221582 221581 221580 221579 221578 221577 221576 221575 221574 221573 221572 221571 221571 221587 221586 221585 221584 221583 221582 221581 221580 221579 221578 221577 221576 221575 221574 221574...
output:
399401324
result:
ok 1 number(s): "399401324"
Test #91:
score: 0
Accepted
time: 1450ms
memory: 63500kb
input:
299999 999056 999055 999054 999053 999052 999051 999050 999049 999049 999051 999052 999053 999054 999055 999056 999051 999056 999055 999054 999053 999053 999051 999051 999052 999053 999054 999055 999056 999057 999058 999059 999051 999056 999055 999054 999053 999052 999051 999058 999057 999056 999055...
output:
969497570
result:
ok 1 number(s): "969497570"
Test #92:
score: 0
Accepted
time: 1292ms
memory: 64728kb
input:
300000 999967 999968 999967 999970 999967 999968 999966 999966 999972 999966 999966 999968 999967 999970 999967 999968 999967 999974 999967 999968 999967 999970 999967 999968 999966 999966 999972 999967 999968 999967 999970 999966 999966 999968 999967 999976 999966 999966 999968 999967 999970 999967...
output:
322980161
result:
ok 1 number(s): "322980161"
Test #93:
score: 0
Accepted
time: 1421ms
memory: 66616kb
input:
300000 999987 999988 999977 999978 999969 999970 999965 999966 999963 999964 999957 999958 999955 999956 999953 999954 999949 999950 999947 999948 999945 999946 999939 999940 999937 999938 999931 999932 999927 999928 999925 999926 999923 999924 999917 999918 999915 999916 999913 999914 999909 999910...
output:
8963291
result:
ok 1 number(s): "8963291"
Test #94:
score: 0
Accepted
time: 1477ms
memory: 66712kb
input:
300000 999989 999989 999991 999986 999987 999983 999983 999985 999980 999981 999978 999979 999974 999975 999970 999971 999962 999963 999958 999959 999940 999941 999928 999929 999926 999927 999920 999921 999918 999919 999916 999917 999912 999913 999906 999907 999902 999903 999900 999901 999898 999899...
output:
299983610
result:
ok 1 number(s): "299983610"
Test #95:
score: 0
Accepted
time: 1429ms
memory: 66388kb
input:
300000 170 171 160 161 156 157 156 159 158 163 154 155 151 151 153 152 157 156 159 150 151 150 153 143 143 145 136 137 136 139 138 141 131 131 133 128 129 124 125 124 127 123 123 125 119 119 121 117 117 119 112 113 111 111 115 114 117 116 123 121 121 131 130 135 133 133 137 135 135 139 138 143 140 1...
output:
8268709
result:
ok 1 number(s): "8268709"
Test #96:
score: 0
Accepted
time: 1341ms
memory: 61060kb
input:
300000 999999 999999 999999 1000000 999999 1000000 1000000 999999 999999 999999 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 999999 999999 1000000 1000000 1000000 999999 999999 1000000 999999 1000000 1000000 1000000 999999 1000000 1000000 1000000 1000000 999999 999...
output:
40275409
result:
ok 1 number(s): "40275409"
Test #97:
score: 0
Accepted
time: 1379ms
memory: 62488kb
input:
300000 999999 999998 999999 1000000 999999 999998 1000000 1000000 1000000 1000000 999999 1000000 999999 1000000 1000000 999999 999998 1000000 999998 999998 999998 1000000 999999 999999 999999 999998 999999 999998 999999 999999 1000000 1000000 999998 999999 999999 999998 1000000 1000000 999999 999998...
output:
682676736
result:
ok 1 number(s): "682676736"
Test #98:
score: 0
Accepted
time: 1467ms
memory: 63816kb
input:
300000 1000000 999999 999999 999997 999997 999998 999999 999997 999998 999999 999997 999998 999997 1000000 999998 999998 999999 999998 1000000 999998 999998 999998 999997 1000000 999998 999998 999998 999998 1000000 999997 999998 999999 999998 999998 999998 1000000 999998 1000000 999998 999998 100000...
output:
221156874
result:
ok 1 number(s): "221156874"
Extra Test:
score: 0
Extra Test Passed