結果

問題 No.281 門松と魔法(1)
コンテスト
ユーザー FF256grhy
提出日時 2015-09-18 23:59:35
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 921 bytes
コンパイル時間 272 ms
コンパイル使用メモリ 23,168 KB
実行使用メモリ 6,824 KB
最終ジャッジ日時 2024-11-06 19:31:16
合計ジャッジ時間 2,774 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 41 WA * 7 RE * 9
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:7:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    7 |         scanf("%d%d%d%d", &d, &h1, &h2, &h3);
      |         ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#include <stdio.h>

#define MAX 2000000000

int main(void) {
	int d, h1, h2, h3;
	scanf("%d%d%d%d", &d, &h1, &h2, &h3);
	
	int a, b, c;
	
	if( (h1 == h2) && (h2 == h3) ) {
		if(h2 > d) { a = 2; } else { a = -1; }
	} else if( (h1 == h3) && (h2 < h1) ) {
		if(h2 <  h1 - d) { a = 1; }
		if(h2 == h1 - d) { if(h2 != 0) { a = 2; } else { a = -1; } }
		if(h2 >  h1 - d) { if(h1 >  d) { a = 2; } else { a = -1; } }
	} else if( ( (h2 == h1) && (h3 < h2) ) || ( (h2 == h3) && (h1 < h2) ) ) { a = 1; }
	else if( (h1 < h2) && (h3 < h2) && (h1 != h3) ) { a = 0; }
	else if( (h1 > h2) && (h3 > h2) && (h1 != h3) ) { a = 0; }
	else {
		if(h1 < h3) { int temp = h1; h1 = h3; h3 = temp; }
		
		b = (h1 - h2) / d + 1;
		if( h1 - d * b == h3 ) {
			if(h3 != 0) { b++; } else { b = MAX; }
		}
		
		c = (h2 - h3) / d + 1;
		if(h3 == 0) { c = MAX; }
		
		a = (b < c ? b : c);
		if(a == MAX) { a = -1; }
	}
	
	printf("%d\n", a);
	return 0;
}
0