結果

問題 No.585 工夫のないパズル
コンテスト
ユーザー %20
提出日時 2017-11-01 15:50:29
言語 C90(gcc12)
(gcc 12.4.0)
コンパイル:
gcc-12 -O2 -std=c90 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 921 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 134 ms
コンパイル使用メモリ 31,560 KB
実行使用メモリ 7,844 KB
最終ジャッジ日時 2026-03-08 16:14:34
合計ジャッジ時間 925 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 12
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c:3:1: warning: data definition has no type or storage class
    3 | p[100],N;
      | ^
main.c: In function ‘main’:
main.c:55:9: warning: incompatible implicit declaration of built-in function ‘printf’ [-Wbuiltin-declaration-mismatch]
   55 |         printf("%d\n",N);
      |         ^~~~~~
main.c:1:1: note: include ‘<stdio.h>’ or provide a declaration of ‘printf’
  +++ |+#include <stdio.h>
    1 | typedef unsigned long long ull;

ソースコード

diff #
raw source code

typedef unsigned long long ull;
ull z;
p[100],N;

idx(n){
	int r,i;
	for(i=0;i<16;++i)(z>>4*i&15)==n?r=15-i:0;
	return r;
}

yoko(r,a){
	ull m=0xffff000000000000ull>>16*(r&=3);
	if(a&=3){
		z=~m&z|m&((m&z)>>4*a|(m&z)<<4*(4-a));
		p[N++]=0<<4|r<<2|a;
	}
}

tate(c,b){
	ull m=0xf000f000f000f000ull>>4*(c&=3);
	if(b&=3){
		z=~m&z|m&((m&z)>>16*b|(m&z)<<16*(4-b));
		p[N++]=1<<4|c<<2|b;
	}
}

main(i,j){
	for(i=0;i<16;++i&3||getchar()){
		z=z<<4|getchar()-1&15;
	}
	for(i=0;i<15;++i){
		for(;i!=(j=idx(i));){
			if(i<12){
				if((i&3)==(j&3)){
					yoko(j>>2,1);
					j=j&12|j+1&3;
				}
				tate(j,3-(j>>2));
				tate(i,3-(i>>2));
				yoko(3,i-j);
				tate(i,(i>>2)-3);
				tate(j,(j>>2)-3);
			}else{
				tate(j,3);
				yoko(3,2);
				tate(j,1);
				yoko(3,1);
				tate(j,3);
				yoko(3,1);
				tate(j,1);
				yoko(3,1);
			}
		}
	}
	printf("%d\n",N);
	for(i=0;i<N;++i)printf("%c %d %d\n","RC"[p[i]>>4],p[i]>>2&3,p[i]&3);
}
0