This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "hexagon.h"
//#include "grader.cpp"
#include <vector>
using namespace std;
#define ll long long
const ll mod=1e9+7;
ll powmod(ll a,ll b,ll mod)
{
if(b==0)
{
return 1;
}
if(b==1)
{
return a;
}
ll cp=powmod(a,b/2,mod);
cp=(cp*cp)%mod;
if(b%2)
{
cp=(cp*a)%mod;
}
return cp;
}
int draw_territory(int N, int A, int B,std::vector<int> D, std::vector<int> L) {
ll total_cell=L[0]+1,two=2;
total_cell=(((total_cell*(total_cell+1))%mod)*powmod(two,mod-2,mod))%mod;
ll ap=A;
ll ans=(total_cell*ap)%mod;
// cell with distance i are i+1
// So (i*b)*(i+1)
// Sum of ((i*(i+1))) *b
ll ab=B;
ll po=(powmod(2,L[0],mod)*ab)%mod;
// (i+1 C 2) = 2**(i+2)
ans=(ans+po)%mod;
return ans;
// return (total_cell*ap)%mod;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |