제출 #89303

#제출 시각아이디문제언어결과실행 시간메모리
89303vvash17새로운 문제 (POI13_luk)C++14
0 / 100
2054 ms35304 KiB
#include <cstdio> #include <vector> #include <algorithm> #include <map> #include <iostream> #include <set> using namespace std; map<int,vector<int> > graph; int city_num,from,to; int evaluate_result(int search_start,int need_num,int* been_there){ int available_neigbours = 0; int sub_tree_res = 0; been_there[search_start]++; for(int i = 0; i<graph[search_start].size(); i++){ if(been_there[graph[search_start][i]] == 0){ available_neigbours++; sub_tree_res += evaluate_result(graph[search_start][i],need_num,been_there); } } int res = available_neigbours-(need_num-sub_tree_res); if(res <= 0)return 0; return res; } int search_init(int need_num){ if(need_num <= 1)return -1; if(need_num == 1)return need_num; int been_there[city_num]; for(int i = 0; i<city_num; i++)been_there[i] = 0; return evaluate_result(1,need_num,been_there); } int main() { scanf("%d",&city_num); for(int i = 1; i<city_num; i++){ scanf("%d %d", &from, &to); graph[from].push_back(to); graph[to].push_back(from); } int result = 1; for(int need_num = 1; need_num<=city_num; need_num++){ result = search_init(need_num); if(result == 0){ result = need_num; break; } } printf("%d \n",&result); return 0; }

컴파일 시 표준 에러 (stderr) 메시지

luk.cpp: In function 'int evaluate_result(int, int, int*)':
luk.cpp:20:18: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0; i<graph[search_start].size(); i++){
                 ~^~~~~~~~~~~~~~~~~~~~~~~~~~~
luk.cpp: In function 'int main()':
luk.cpp:56:24: warning: format '%d' expects argument of type 'int', but argument 2 has type 'int*' [-Wformat=]
  printf("%d \n",&result);
                 ~~~~~~~^
luk.cpp:40:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d",&city_num);
  ~~~~~^~~~~~~~~~~~~~~~
luk.cpp:42:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d %d", &from, &to);
   ~~~~~^~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...