답안 #529750

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
529750 2022-02-23T15:18:04 Z Koosha_mv Meetings (JOI19_meetings) C++14
컴파일 오류
0 ms 0 KB
#include <bits/stdc++.h>
using namespace std;
#define dbgv(v) cout<<#v<<" = "; f(i,0,v.size()) cout<<v[i]<<" "; cout<<endl
#define dbga(a,x,y) cout<<#a<<" = "; f(i,x,y) cout<<a[i]<<" "; cout<<endl
#define erorp(x) cout<<#x<<"={"<<(x.F)<<" , "<<x.S<<"}"<<endl
#define eror(x) cout<<#x<<'='<<(x)<<endl
#define f_(i,a,b) for(int i=a;i>=b;i--)
#define f(i,a,b) for(int i=a;i<b;i++)
#define nb(x) __builtin_popcount(x)
#define all(v) v.begin(),v.end()
#define bit(n,k) (((n)>>(k))&1)
#define Add(x,y) x=(x+y)%mod
#define maxm(a,b) a=max(a,b)
#define minm(a,b) a=min(a,b)
#define lst(x) x[x.size()-1]
#define sz(x) int(x.size())
#define mp make_pair
#define ll long long
#define pb push_back
#define S second
#define F first
#include meetings.h

const int N=2020;

int n;
/*
void Bridge(int u, int v){
	cout<<"BRIDGE "<<u<<" "<<v<<endl;
}
int Query(int u, int v, int w){
	
}*/
void findpath(vector<int> p){
	vector<int> res;
	res.pb(p[0]);
	res.pb(p[1]);
	f(i,2,p.size()){
		int u=p[i];
		int l,r;
		if(Query(u,res[0],res[1])==res[0]){
			l=-1,r=0;
		}
		else{
			int l=0,r=res.size();
			while(l+1<r){
				int mid=(l+r)>>1;
				if(Query(u,res[mid],res[mid-1])==res[mid]) l=mid;
				else r=mid;
			}
		}
		vector<int> pes;
		f(i,0,res.size()){
			if(i==r) pes.pb(u);
			pes.pb(res[i]);
		}
		if(r==res.size()) pes.pb(u);
		res=pes;
	}
	f(i,1,res.size()){
		Bridge(res[i],res[i-1]);
	}
}
void solve(vector<int> vec){
	if(vec.size()==1) return ;
	vector<int> path;
	vector<pair<int,int>> e;
	int u=0,v=0;
	while(u==v) u=rand()%vec.size(),v=rand()%vec.size();
	u=vec[u],v=vec[v];
	e.pb({u,u});
	e.pb({v,v});
	for(auto x : vec){
		if(x==u || x==v) continue ;
		e.pb({Query(x,u,v),x});
	}	
	sort(all(e));
	vec.clear();
	f(i,0,e.size()){
		vec.pb(e[i].S);
		if(i==e.size()-1 || e[i].F!=e[i+1].F){
			path.pb(e[i].F);
			solve(vec);
			vec.clear();
		}
	}
	findpath(path);
}
void Solve(int pn){
	n=pn;
	vector<int> vec(n);
	iota(all(vec),0);
	solve(vec);
}
int main(){
	srand(time(NULL));	
}

Compilation message

meetings.cpp:22:10: error: #include expects "FILENAME" or <FILENAME>
   22 | #include meetings.h
      |          ^~~~~~~~
meetings.cpp: In function 'void findpath(std::vector<int>)':
meetings.cpp:8:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    8 | #define f(i,a,b) for(int i=a;i<b;i++)
......
   38 |  f(i,2,p.size()){
      |    ~~~~~~~~~~~~                
meetings.cpp:38:2: note: in expansion of macro 'f'
   38 |  f(i,2,p.size()){
      |  ^
meetings.cpp:41:6: error: 'Query' was not declared in this scope
   41 |   if(Query(u,res[0],res[1])==res[0]){
      |      ^~~~~
meetings.cpp:8:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    8 | #define f(i,a,b) for(int i=a;i<b;i++)
......
   53 |   f(i,0,res.size()){
      |     ~~~~~~~~~~~~~~             
meetings.cpp:53:3: note: in expansion of macro 'f'
   53 |   f(i,0,res.size()){
      |   ^
meetings.cpp:57:7: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   57 |   if(r==res.size()) pes.pb(u);
      |      ~^~~~~~~~~~~~
meetings.cpp:8:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    8 | #define f(i,a,b) for(int i=a;i<b;i++)
......
   60 |  f(i,1,res.size()){
      |    ~~~~~~~~~~~~~~              
meetings.cpp:60:2: note: in expansion of macro 'f'
   60 |  f(i,1,res.size()){
      |  ^
meetings.cpp:61:3: error: 'Bridge' was not declared in this scope
   61 |   Bridge(res[i],res[i-1]);
      |   ^~~~~~
meetings.cpp: In function 'void solve(std::vector<int>)':
meetings.cpp:75:9: error: 'Query' was not declared in this scope
   75 |   e.pb({Query(x,u,v),x});
      |         ^~~~~
meetings.cpp:75:24: error: no matching function for call to 'std::vector<std::pair<int, int> >::push_back(<brace-enclosed initializer list>)'
   75 |   e.pb({Query(x,u,v),x});
      |                        ^
In file included from /usr/include/c++/10/vector:67,
                 from /usr/include/c++/10/queue:61,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:86,
                 from meetings.cpp:1:
/usr/include/c++/10/bits/stl_vector.h:1187:7: note: candidate: 'void std::vector<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = std::pair<int, int>; _Alloc = std::allocator<std::pair<int, int> >; std::vector<_Tp, _Alloc>::value_type = std::pair<int, int>]'
 1187 |       push_back(const value_type& __x)
      |       ^~~~~~~~~
/usr/include/c++/10/bits/stl_vector.h:1187:35: note:   no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'const value_type&' {aka 'const std::pair<int, int>&'}
 1187 |       push_back(const value_type& __x)
      |                 ~~~~~~~~~~~~~~~~~~^~~
/usr/include/c++/10/bits/stl_vector.h:1203:7: note: candidate: 'void std::vector<_Tp, _Alloc>::push_back(std::vector<_Tp, _Alloc>::value_type&&) [with _Tp = std::pair<int, int>; _Alloc = std::allocator<std::pair<int, int> >; std::vector<_Tp, _Alloc>::value_type = std::pair<int, int>]'
 1203 |       push_back(value_type&& __x)
      |       ^~~~~~~~~
/usr/include/c++/10/bits/stl_vector.h:1203:30: note:   no known conversion for argument 1 from '<brace-enclosed initializer list>' to 'std::vector<std::pair<int, int> >::value_type&&' {aka 'std::pair<int, int>&&'}
 1203 |       push_back(value_type&& __x)
      |                 ~~~~~~~~~~~~~^~~
meetings.cpp:8:31: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    8 | #define f(i,a,b) for(int i=a;i<b;i++)
......
   79 |  f(i,0,e.size()){
      |    ~~~~~~~~~~~~                
meetings.cpp:79:2: note: in expansion of macro 'f'
   79 |  f(i,0,e.size()){
      |  ^
meetings.cpp:81:7: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   81 |   if(i==e.size()-1 || e[i].F!=e[i+1].F){
      |      ~^~~~~~~~~~~~