# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
675908 | 2022-12-28T10:41:07 Z | QwertyPi | Energetic turtle (IZhO11_turtle) | C++14 | Compilation error |
0 ms | 0 KB |
#include <bits/stdc++.h> #define int __int128_t #define fi first #define se second using namespace std; const int MAXN = 6e5 + 11; int phi = 1; map<int, int> pf; map<int, int> f[MAXN]; int pm(int a, int b, int Z){ if(b == 0) return 1; return pm(a * a % Z, b / 2, Z) * (b % 2 ? a : 1) % Z; } int mi(int a, int Z){ a %= Z; return pm(a, phi - 1, Z); } int C(int n, int r, int Z){ if(n < r || r < 0) return 0; map<int, int> res; res[0] = 1; for(auto i : f[n]){ if(i.fi == 0){ res[0] = (res[0] * i.se) % Z; }else{ res[i.fi] += i.se; } } for(auto i : f[r]){ if(i.fi == 0){ res[0] = (res[0] * mi(i.se, Z)) % Z; }else{ res[i.fi] -= i.se; } } for(auto i : f[n - r]){ if(i.fi == 0){ res[0] = (res[0] * mi(i.se, Z)) % Z; }else{ res[i.fi] -= i.se; } } int ans = 1; for(auto i : res){ if(i.fi == 0){ ans *= i.se; continue; } for(int j = 0; j < i.se; j++){ ans *= i.fi; ans %= Z; } } return ans; } int p[25][2], d[22][25]; int Cu[25]; int32_t main(){ int64_t N, M, K, T, Z; cin >> N >> M >> K >> T >> Z; phi = Z; int z = Z; for(int i = 2; i <= sqrt(1e9) + 11; i++){ if(z % i == 0) phi = phi / i * (i - 1); while(z % i == 0) pf[i]++, z /= i; } if(z != 1) phi = phi / z * (z - 1), pf[z]++; f[0][0] = 1; for(int i = 1; i <= MAXN - 1; i++){ f[i] = f[i - 1]; int x = i; for(auto p : pf){ while(x % p.fi == 0){ f[i][p.fi]++; x /= p.fi; } } f[i][0] = f[i - 1][0] * x % Z; } p[0][0] = 0, p[0][1] = 0; p[K + 1][0] = N, p[K + 1][1] = M; vector<pair<int, int>> v; for(int i = 0; i < K; i++){ int x, y; cin >> x >> y; v.push_back({x, y}); } sort(v.begin(), v.end()); for(int i = 1; i <= K; i++){ p[i][0] = v[i - 1].fi, p[i][1] = v[i - 1].se; } for(int i = 0; i <= K + 1; i++){ for(int j = 0; j <= K + 1; j++){ int dx = p[j][0] - p[i][0]; int dy = p[j][1] - p[i][1]; d[i][j] = C(dx + dy, dx, Z); } } for(int i = 0; i <= K; i++){ Cu[i] = C(i, T + 1, Z); } int s = C(N + M, N, Z), t = 0; for(int i = 0; i < (1 << K); i++){ int U = __builtin_popcount(i); if(U >= T + 1){ int f = 1, pv = 0; for(int j = 0; j < K; j++){ if(i & (1 << j)){ f = f * d[pv][j + 1] % Z; pv = j + 1; } } f = f * d[pv][K + 1] % Z; t += ((U + T + 1) % 2 ? -1 : 1) * Cu[U] * f % Z; t %= Z; } } cout << (long long)((s - t) % Z + Z) % Z << endl; }
Compilation message
turtle.cpp: In function 'int32_t main()': turtle.cpp:92:17: error: no match for 'operator>>' (operand types are 'std::istream' {aka 'std::basic_istream<char>'} and '__int128') 92 | int x, y; cin >> x >> y; | ~~~ ^~ ~ | | | | | __int128 | std::istream {aka std::basic_istream<char>} In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:120:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(std::basic_istream<_CharT, _Traits>::__istream_type& (*)(std::basic_istream<_CharT, _Traits>::__istream_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 120 | operator>>(__istream_type& (*__pf)(__istream_type&)) | ^~~~~~~~ /usr/include/c++/10/istream:120:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: invalid conversion from '__int128' to 'std::basic_istream<char>::__istream_type& (*)(std::basic_istream<char>::__istream_type&)' {aka 'std::basic_istream<char>& (*)(std::basic_istream<char>&)'} [-fpermissive] 92 | int x, y; cin >> x >> y; | ^ | | | __int128 In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:124:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(std::basic_istream<_CharT, _Traits>::__ios_type& (*)(std::basic_istream<_CharT, _Traits>::__ios_type&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>; std::basic_istream<_CharT, _Traits>::__ios_type = std::basic_ios<char>]' (near match) 124 | operator>>(__ios_type& (*__pf)(__ios_type&)) | ^~~~~~~~ /usr/include/c++/10/istream:124:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: invalid conversion from '__int128' to 'std::basic_istream<char>::__ios_type& (*)(std::basic_istream<char>::__ios_type&)' {aka 'std::basic_ios<char>& (*)(std::basic_ios<char>&)'} [-fpermissive] 92 | int x, y; cin >> x >> y; | ^ | | | __int128 In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:131:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(std::ios_base& (*)(std::ios_base&)) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 131 | operator>>(ios_base& (*__pf)(ios_base&)) | ^~~~~~~~ /usr/include/c++/10/istream:131:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: invalid conversion from '__int128' to 'std::ios_base& (*)(std::ios_base&)' [-fpermissive] 92 | int x, y; cin >> x >> y; | ^ | | | __int128 In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:168:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(bool&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 168 | operator>>(bool& __n) | ^~~~~~~~ /usr/include/c++/10/istream:168:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'bool&' to an rvalue of type 'bool' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:172:7: note: candidate: 'std::basic_istream<_CharT, _Traits>& std::basic_istream<_CharT, _Traits>::operator>>(short int&) [with _CharT = char; _Traits = std::char_traits<char>]' (near match) 172 | operator>>(short& __n); | ^~~~~~~~ /usr/include/c++/10/istream:172:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'short int&' to an rvalue of type 'short int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:175:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(short unsigned int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 175 | operator>>(unsigned short& __n) | ^~~~~~~~ /usr/include/c++/10/istream:175:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'short unsigned int&' to an rvalue of type 'short unsigned int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:179:7: note: candidate: 'std::basic_istream<_CharT, _Traits>& std::basic_istream<_CharT, _Traits>::operator>>(int&) [with _CharT = char; _Traits = std::char_traits<char>]' (near match) 179 | operator>>(int& __n); | ^~~~~~~~ /usr/include/c++/10/istream:179:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'int&' to an rvalue of type 'int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:182:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(unsigned int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 182 | operator>>(unsigned int& __n) | ^~~~~~~~ /usr/include/c++/10/istream:182:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'unsigned int&' to an rvalue of type 'unsigned int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:186:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(long int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 186 | operator>>(long& __n) | ^~~~~~~~ /usr/include/c++/10/istream:186:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'long int&' to an rvalue of type 'long int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:190:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(long unsigned int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 190 | operator>>(unsigned long& __n) | ^~~~~~~~ /usr/include/c++/10/istream:190:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'long unsigned int&' to an rvalue of type 'long unsigned int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:195:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(long long int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 195 | operator>>(long long& __n) | ^~~~~~~~ /usr/include/c++/10/istream:195:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'long long int&' to an rvalue of type 'long long int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:199:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(long long unsigned int&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 199 | operator>>(unsigned long long& __n) | ^~~~~~~~ /usr/include/c++/10/istream:199:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'long long unsigned int&' to an rvalue of type 'long long unsigned int' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:214:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(float&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 214 | operator>>(float& __f) | ^~~~~~~~ /usr/include/c++/10/istream:214:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'float&' to an rvalue of type 'float' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:218:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(double&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 218 | operator>>(double& __f) | ^~~~~~~~ /usr/include/c++/10/istream:218:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'double&' to an rvalue of type 'double' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:222:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(long double&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 222 | operator>>(long double& __f) | ^~~~~~~~ /usr/include/c++/10/istream:222:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: cannot bind non-const lvalue reference of type 'long double&' to an rvalue of type 'long double' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:235:7: note: candidate: 'std::basic_istream<_CharT, _Traits>::__istream_type& std::basic_istream<_CharT, _Traits>::operator>>(void*&) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__istream_type = std::basic_istream<char>]' (near match) 235 | operator>>(void*& __p) | ^~~~~~~~ /usr/include/c++/10/istream:235:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: invalid conversion from '__int128' to 'void*' [-fpermissive] 92 | int x, y; cin >> x >> y; | ^ | | | __int128 turtle.cpp:92:20: error: cannot bind rvalue '(void*)((long int)x)' to 'void*&' In file included from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/istream:259:7: note: candidate: 'std::basic_istream<_CharT, _Traits>& std::basic_istream<_CharT, _Traits>::operator>>(std::basic_istream<_CharT, _Traits>::__streambuf_type*) [with _CharT = char; _Traits = std::char_traits<char>; std::basic_istream<_CharT, _Traits>::__streambuf_type = std::basic_streambuf<char>]' (near match) 259 | operator>>(__streambuf_type* __sb); | ^~~~~~~~ /usr/include/c++/10/istream:259:7: note: conversion of argument 1 would be ill-formed: turtle.cpp:92:20: error: invalid conversion from '__int128' to 'std::basic_istream<char>::__streambuf_type*' {aka 'std::basic_streambuf<char>*'} [-fpermissive] 92 | int x, y; cin >> x >> y; | ^ | | | __int128 turtle.cpp:92:17: note: candidate: 'operator>>(int, __int128)' (built-in) 92 | int x, y; cin >> x >> y; | ~~~~^~~~ turtle.cpp:92:17: note: no known conversion for argument 1 from 'std::istream' {aka 'std::basic_istream<char>'} to 'int' In file included from /usr/include/c++/10/string:56, from /usr/include/c++/10/bits/locale_classes.h:40, from /usr/include/c++/10/bits/ios_base.h:41, from /usr/include/c++/10/ios:42, from /usr/include/c++/10/istream:38, from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from turtle.cpp:1: /usr/include/c++/10/bits/basic_string.tcc:1476:5: note: candidate: 'template<class _CharT, class _Traits, class _Alloc> std::basic_istream<_CharT, _Traits>& std::operator>>(std::basic_istream<_CharT, _Traits>&, std::__cxx11::basic_string<_CharT, _Traits, _Alloc>&)' 1476 | operator>>(basic_istream<_CharT, _Traits>& __in, | ^~~~~~~~ /usr/include/c++/10/bits/basic_string.tcc:1476:5: note: template argument deduction/substitution failed: turtle.cpp:92:20: note: mismatched types 'std::__cxx11::basic_string<_CharT, _Traits, _Alloc>' and '__int128' 92 | int x, y; cin >> x >> y; | ^ In file included from /usr/include/c++/10/istream:991, from /usr/include/c++/10/sstream:38, from /usr/include/c++/10/complex:45, from /usr/include/c++/10/ccomplex:39, from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:54, from /var/local/lib/