# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
981409 | Faisal_Saqib | 육각형 영역 (APIO21_hexagon) | C++17 | 0 ms | 0 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#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 po=(powmod(2,n+1,mod)*b)%mod;
// (i+1 C 2) = 2**(i+2)
ans=(ans+po)%mod;
return ans;
// return (total_cell*ap)%mod;
}