# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
378356 | EIMONIM | Broken Device (JOI17_broken_device) | C++14 | 66 ms | 2880 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define ll long long
#include "Annalib.h"
using namespace std;
pair<int,int>val(int x)
{
if (x==0)
return {0,1};
if (x==1)
return {1,0};
return {1,1};
}
void Anna(int n,ll x,int k,int p[])
{
srand(139);
vector<int>aux(n);
int i;
for(i=0;i<n;i++)
aux[i]=i;
random_shuffle(aux.begin(),aux.end());
vector<bool>poz(n,0),ans(n);
for(i=0;i<k;i++)
poz[p[i]]=1;
for(i=0;i<n;i+=2){
auto num=val(x%3);
if ((poz[aux[i]]==0 || 0) && (poz[aux[i+1]]==0 || 0)){
ans[aux[i]]=num.first;
ans[aux[i+1]]=num.second;
x=x/3;
}
}
for(i=0;i<n;i++)
Set(i,ans[i]);
}
#include<bits/stdc++.h>
#define ll long long
#include "Brunolib.h"
using namespace std;
int val(pair<int,int>num)
{
if (num.first+num.second==2)
return 2;
return num.first;
}
ll Bruno(int n,int a[])
{
srand(139);
vector<int>aux(n);
int i;
for(i=0;i<n;i++)
aux[i]=i;
random_shuffle(aux.begin(),aux.end());
ll ans=0,po=1;
for(i=0;i<n;i+=2){
if (a[aux[i]] || a[aux[i+1]]){
ans=ans+po*val({a[aux[i]],a[aux[i+1]]});
po=po*3;
}
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |