結果

問題 No.2104 Multiply-Add
ユーザー 👑 ygussanyygussany
提出日時 2022-09-29 20:35:38
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 1 ms / 2,000 ms
コード長 2,275 bytes
コンパイル時間 446 ms
コンパイル使用メモリ 32,000 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-06-02 02:07:28
合計ジャッジ時間 1,923 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
5,248 KB
testcase_01 AC 1 ms
5,376 KB
testcase_02 AC 1 ms
5,376 KB
testcase_03 AC 1 ms
5,376 KB
testcase_04 AC 1 ms
5,376 KB
testcase_05 AC 0 ms
5,376 KB
testcase_06 AC 1 ms
5,376 KB
testcase_07 AC 1 ms
5,376 KB
testcase_08 AC 1 ms
5,376 KB
testcase_09 AC 1 ms
5,376 KB
testcase_10 AC 1 ms
5,376 KB
testcase_11 AC 1 ms
5,376 KB
testcase_12 AC 1 ms
5,376 KB
testcase_13 AC 1 ms
5,376 KB
testcase_14 AC 1 ms
5,376 KB
testcase_15 AC 1 ms
5,376 KB
testcase_16 AC 1 ms
5,376 KB
testcase_17 AC 1 ms
5,376 KB
testcase_18 AC 1 ms
5,376 KB
testcase_19 AC 1 ms
5,376 KB
testcase_20 AC 1 ms
5,376 KB
testcase_21 AC 1 ms
5,376 KB
testcase_22 AC 1 ms
5,376 KB
testcase_23 AC 1 ms
5,376 KB
testcase_24 AC 1 ms
5,376 KB
testcase_25 AC 1 ms
5,376 KB
testcase_26 AC 1 ms
5,376 KB
testcase_27 AC 1 ms
5,376 KB
testcase_28 AC 1 ms
5,376 KB
testcase_29 AC 1 ms
5,376 KB
testcase_30 AC 1 ms
5,376 KB
testcase_31 AC 1 ms
5,376 KB
testcase_32 AC 1 ms
5,376 KB
testcase_33 AC 1 ms
5,376 KB
testcase_34 AC 1 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <stdio.h>
#include <stdlib.h>

int gcd(int a, int b)
{
	if (a == 0) return b;
	else return gcd(b % a, a);
}

int main()
{
	int a, b, c, d;
	scanf("%d %d %d %d", &a, &b, &c, &d);
	
	int g = gcd(abs(a), abs(b));
	if (g != gcd(abs(c), abs(d))) {
		printf("-1\n");
		fflush(stdout);
		return 0;
	} else if (g == 0) {
		printf("0\n");
		fflush(stdout);
		return 0;
	}
	
	int k = 0, x, ans[1001][2];
	if (a <= 0) {
		if (b == 0) {
			ans[k][0] = 2;
			ans[k++][1] = -1;
			b = -a;
		}
		if (b > 0) {
			x = abs(a) / b + 1;
			ans[k][0] = 1;
			ans[k++][1] = x;
			a += b * x;
		} else {
			x = abs(a) / abs(b) + 1;
			ans[k][0] = 1;
			ans[k++][1] = -x;
			a -= b * x;
		}
	}
	if (b <= 0) {
		if (a == 0) {
			ans[k][0] = 1;
			ans[k++][1] = -1;
			a = -b;
		}
		if (a > 0) {
			x = abs(b) / a + 1;
			ans[k][0] = 2;
			ans[k++][1] = x;
			b += a * x;
		} else {
			x = abs(b) / abs(a) + 1;
			ans[k][0] = 1;
			ans[k++][1] = -x;
			b -= a * x;
		}
	}
	while (a != g || b != g) {
		if (a > b) {
			x = a / b;
			if (a % b == 0) x--;
			ans[k][0] = 1;
			ans[k++][1] = -x;
			a -= b * x;
		} else {
			x = b / a;
			if (b % a == 0) x--;
			ans[k][0] = 2;
			ans[k++][1] = -x;
			b -= a * x;
		}
	}
	
	int kk = 0, anss[1001][2];
	a = c;
	b = d;
	if (a <= 0) {
		if (b == 0) {
			anss[kk][0] = 2;
			anss[kk++][1] = 1;
			b = -a;
		}
		if (b > 0) {
			x = abs(a) / b + 1;
			anss[kk][0] = 1;
			anss[kk++][1] = -x;
			a += b * x;
		} else {
			x = abs(a) / abs(b) + 1;
			anss[kk][0] = 1;
			anss[kk++][1] = x;
			a -= b * x;
		}
	}
	if (b <= 0) {
		if (a == 0) {
			anss[kk][0] = 1;
			anss[kk++][1] = 1;
			a = -b;
		}
		if (a > 0) {
			x = abs(b) / a + 1;
			anss[kk][0] = 2;
			anss[kk++][1] = -x;
			b += a * x;
		} else {
			x = abs(b) / abs(a) + 1;
			anss[kk][0] = 1;
			anss[kk++][1] = x;
			b -= a * x;
		}
	}
	while (a != g || b != g) {
		if (a > b) {
			x = a / b;
			if (a % b == 0) x--;
			anss[kk][0] = 1;
			anss[kk++][1] = x;
			a -= b * x;
		} else {
			x = b / a;
			if (b % a == 0) x--;
			anss[kk][0] = 2;
			anss[kk++][1] = x;
			b -= a * x;
		}
	}
	
	int i;
	printf("%d\n", k + kk);
	for (i = 0; i < k; i++) printf("%d %d\n", ans[i][0], ans[i][1]);
	for (i = kk - 1; i >= 0; i--) printf("%d %d\n", anss[i][0], anss[i][1]);
	fflush(stdout);
	return 0;
}
0