이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "supertrees.h"
#include<bits/stdc++.h>
using namespace std;
void markall(int i ,int j ,vector<int>&f,vector<int>&b,vector<vector<int>>&p,vector<vector<int>>&answer){
int k = b[i];
while(k!=-1){
int u = j;
while(u!=-1){
if (!answer[k][u]){
p[k][u]--;
p[u][k]--;
answer[k][u]++;
answer[u][k]++;}
u=f[u];}
k=b[k];
}
}
bool check(vector<int>f,vector<int>b,int i ,int j,vector<vector<int>>p){
int k = b[i];
while(k!=-1){
int u = j;
while(u!=-1){
if (p[k][u]<=0)return false;
u=f[u];}
k=b[k];
}
return true;
}
int construct(vector<std::vector<int>> p) {
int n = p.size();
vector<vector<int>>answer(n,vector<int>(n,0));
vector<pair<int,int>>ans;
/*
1 1 0 0 - 0 - 1
1 1 1 0 0 - 1 - 2
1 0 1 1 2 - 3
1 0 1 0
//0 - 1 - 2 - 3 - 4
*/
for (int i =0;i<n;++i){
for (int j=i+1;j<n;++j){
if(p[i][j] == 0)
{
for(int h = 0; h < n; h++)
{
if(p[i][h] == 1 && p[j][h] == 1)return 0;
}
}
}
}
for (int i =0;i<n;++i){
for (int j =0;j<n;++j){
if (p[i][j]==1){
if (j==i+1||j==i-1)answer[i][j]=1;}
else ans.push_back({i,j});
}
}
build(answer);
return 1;
}
# | 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... |