結果

問題 No.977 アリス仕掛けの摩天楼
コンテスト
ユーザー 👑 tails
提出日時 2020-10-23 09:58:47
言語 C(gnu17)
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -std=gnu17 -Wno-error=implicit-function-declaration -Wno-error=implicit-int -Wno-error=incompatible-pointer-types -Wno-error=int-conversion -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
CE  
(最新)
AC  
(最初)
実行時間 -
コード長 734 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 146 ms
コンパイル使用メモリ 28,440 KB
最終ジャッジ日時 2026-02-22 06:14:30
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
コンパイルエラー時のメッセージ・ソースコードは、提出者また管理者しか表示できないようにしております。(リジャッジ後のコンパイルエラーは公開されます)
ただし、clay言語の場合は開発者のデバッグのため、公開されます。

コンパイルメッセージ
main.c:13:1: error: return type defaults to 'int' [-Wimplicit-int]
   13 | main(){
      | ^~~~
main.c: In function 'main':
main.c:46:17: error: implicit declaration of function 'write' [-Wimplicit-function-declaration]
   46 |                 write(1,"Bob",3);
      |                 ^~~~~
main.c:50:9: error: implicit declaration of function '_exit' [-Wimplicit-function-declaration]
   50 |         _exit(0);
      |         ^~~~~
main.c:50:9: warning: incompatible implicit declaration of built-in function '_exit' [-Wbuiltin-declaration-mismatch]

ソースコード

diff #
raw source code

#pragma GCC optimize("Ofast")
#pragma GCC target("avx2")

#include <sys/mman.h>

int ufb[100000];
int h[100000];

int uf(int i){ return ufb[i]>=0?ufb[i]=uf(ufb[i]):i; }

#define RD(v) for(v=0;c=*r++-48,c>=0;v=v*10+c)

main(){
	char*r=mmap(0,1200*1024,PROT_READ,MAP_PRIVATE,0,0);
	int c;

	int n; RD(n);

	for(int i=0;i<n;++i){
		ufb[i]=-1;
	}

	int c1=0;
	int c2=n;
	while(--n){
		int u; RD(u);
		int v; RD(v);
		if(++h[u]==2) --c2;
		if(++h[v]==2) --c2;
		int ur=uf(u);
		int vr=uf(v);
		if(ur==vr){
			++c1;
		}else{
			if(ufb[ur]>ufb[vr]){
				ufb[vr]+=ufb[ur];
				ufb[ur]=vr;
			}else{
				ufb[ur]+=ufb[vr];
				ufb[vr]=ur;
			}
		}
	}

	if(c1==0||c1==1&&c2==1){
		write(1,"Bob",3);
	}else{
		write(1,"Alice",5);
	}
	_exit(0);
}
0