結果
| 問題 | 
                            No.3109 Swap members
                             | 
                    
| コンテスト | |
| ユーザー | 
                             tails
                         | 
                    
| 提出日時 | 2025-04-23 13:45:03 | 
| 言語 | C  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 13 ms / 2,000 ms | 
| コード長 | 926 bytes | 
| コンパイル時間 | 1,252 ms | 
| コンパイル使用メモリ | 26,368 KB | 
| 実行使用メモリ | 7,848 KB | 
| 最終ジャッジ日時 | 2025-04-23 13:45:07 | 
| 合計ジャッジ時間 | 3,457 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 52 | 
コンパイルメッセージ
main.c: In function ‘main’:
main.c:46:33: warning: implicit declaration of function ‘write’ [-Wimplicit-function-declaration]
   46 |                                 write(1,"No",2);
      |                                 ^~~~~
main.c:47:33: warning: implicit declaration of function ‘_exit’ [-Wimplicit-function-declaration]
   47 |                                 _exit(0);
      |                                 ^~~~~
main.c:47:33: warning: incompatible implicit declaration of built-in function ‘_exit’ [-Wbuiltin-declaration-mismatch]
main.c:60:9: warning: incompatible implicit declaration of built-in function ‘_exit’ [-Wbuiltin-declaration-mismatch]
   60 |         _exit(0);
      |         ^~~~~
            
            ソースコード
#pragma GCC optimize("Ofast")
#pragma GCC target("avx2")
#define rd_init() char*rp=({char*mmap();mmap(0l,1l<<25,1,2,0,0ll);})
#define rd() ({int _v=0,_c;while(_c=*rp++-48,_c>=0)_v=_v*10+_c;_v;})
#define repeat(e) for(typeof(e)_=e;_--;)
#define HASH_BITS 18
#define HASH_N    (1<<HASH_BITS)
#define HASH_MASK (HASH_N-1)
long hash[HASH_N];
int main(){
	rd_init();
	int n=rd();
	int k=rd();
	int a=0;
	repeat(n){
		long x=1;
		for(int c;c=*rp++,c&64;){
			x=x*67+c;
		}
		x=x*k+a;
		int h=x&HASH_MASK;
		while(1){
			if(hash[h]==0){
				hash[h]=x;
				break;
			}
			h=h+k&HASH_MASK;
		}
		if(++a==k){
			a=0;
		}
	}
	a=0;
	repeat(n){
		long x=1;
		for(int c;c=*rp++,c&64;){
			x=x*67+c;
		}
		x=x*k+a;
		int h=x&HASH_MASK;
		while(1){
			if(hash[h]==0){
				write(1,"No",2);
				_exit(0);
				break;
			}
			if(hash[h]==x){
				break;
			}
			h=h+k&HASH_MASK;
		}
		if(++a==k){
			a=0;
		}
	}
	write(1,"Yes",3);
	_exit(0);
}
            
            
            
        
            
tails