이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
#define all(x) x.begin() , x.end()
#define sze(x) (ll)(x.size())
typedef long long ll;
typedef pair<ll , ll> pll;
typedef pair<pll , bool> pllb;
const ll maxn = 2e5 + 16 , md = 1e9 + 7;
ll tav(ll n , ll k){
ll res = 1;
while(k > 0){
if(k & 1){
res *= n; res %= md;
}
n *= n; n %= md;
k >>= 1;
}
return res;
}
vector<pllb> a , b;
ll ant , bnt;
int main(){
ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);
ll n , m , k;
cin>>n>>m>>k;
for(ll i = 0 ; i < k ; i++){
ll v , u;
char c;
cin>>c>>v>>u;
a.push_back({{v , u} , (c == '+')});
b.push_back({{u , v} , (c == '+')});
}
sort(all(a)); sort(all(b));
ant = bnt = 1;
bool ad = false , bd = false;
for(ll i = 1 ; i < k ; i++){
if(a[i].first.first != a[i - 1].first.first){
ant++;
continue;
}
bool c = (a[i].first.second - a[i - 1].first.second) & 1 , d = (a[i].second ^ a[i - 1].second) , h;
h = c ^ d;
ad |= h;
}
for(ll i = 1 ; i < k ; i++){
if(b[i].first.first != b[i - 1].first.first){
bnt++;
continue;
}
bool c = (b[i].first.second - b[i - 1].first.second) & 1 , d = (b[i].second ^ b[i - 1].second) , h;
h = c ^ d;
bd |= h;
}
if(ad & bd){
cout<<"0\n";
return 0;
}
ll ans;
if(!ad & !bd){
ans = tav(2 , n - ant) + tav(2 , m - bnt) - 1; if(ans >= md) ans -= md;
if(k == 0){
ans <<= 1;
if(ans >= md) ans -= md;
}
cout<<ans<<'\n';
return 0;
}
if(bd){
ans = tav(2 , n - ant);
cout<<ans<<'\n';
return 0;
}
ans = tav(2 , m - bnt);
cout<<ans<<'\n';
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |