結果
| 問題 | No.26 シャッフルゲーム | 
| コンテスト | |
| ユーザー |  subsn | 
| 提出日時 | 2023-05-30 11:00:39 | 
| 言語 | C (gcc 13.3.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 1 ms / 5,000 ms | 
| コード長 | 1,593 bytes | 
| コンパイル時間 | 331 ms | 
| コンパイル使用メモリ | 30,336 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-12-28 11:39:28 | 
| 合計ジャッジ時間 | 1,093 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 10 | 
ソースコード
#include <stdio.h>
#include <malloc.h>
char str[60000];
int str_len = 0;
/// <summary>
/// グローバル変数strの中身を入力された文字列で上書きする
/// </summary>
void ReadString() {
	char c = getchar();
	str_len = 0;
	while (c != '\n') {
		str[str_len] = c;
		c = getchar();
		str_len++;
	}
}
/// <summary>
/// 入力された数字を返す
/// </summary>
/// <returns></returns>
int ReadNum() {
	int negate = 0;
	char c = getchar();
	int num = 0;
	int numCnt = 0;
	while (c != '\n') {
		if (c == '-') {
			negate = 1;
		}
		else {
			num = num * 10 + c - '0';
		}
		c = getchar();
	}
	if (negate == 1) {
		num *= -1;
	}
	return num;
}
/// <summary>
/// ReadStringの文字列のうち、スペースで区切られた左側か右側を取得する
/// </summary>
/// <param name="leftIs">左が欲しければtrue,右ならfalse</param>
/// <returns>引数に対応した側の数字を返す</returns>
int GetLR(int leftIs) {
	int cnt = 0;
	int num = 0;
	int left = 0;
	int right = 0;
	while (1) {
		if (cnt >= str_len) {
			right = num;
			break;
		}
		if (str[cnt] == ' ') {
			left = num;
			num = 0;
			cnt++;
			continue;
		}
		num = num * 10 + (str[cnt] - '0');
		cnt++;
	}
	if (leftIs) {
		return left;
	}
	else {
		return right;
	}
}
int main()
{
	int cups[3] = { 0,0,0 };
	cups[ReadNum()-1] = 1;
	int n = ReadNum();
	for (int i = 0;i < n;i++) {
		ReadString();
		int work = cups[GetLR(1) - 1];
		cups[GetLR(1) - 1] = cups[GetLR(0) - 1];
		cups[GetLR(0) - 1] = work;
	}
	for (int i = 0;i < 3;i++) {
		if (cups[i] == 1) {
			printf("%d\n",i+1);
		}
	}
}
            
            
            
        