結果
| 問題 |
No.24 数当てゲーム
|
| コンテスト | |
| ユーザー |
subsn
|
| 提出日時 | 2023-05-30 09:32:09 |
| 言語 | C (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 1,686 bytes |
| コンパイル時間 | 2,059 ms |
| コンパイル使用メモリ | 29,312 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-12-28 11:33:52 |
| 合計ジャッジ時間 | 1,190 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;
}
void ExtractNums(int* nums) {
ReadString();
for (int i = 0;i < 7;i++) {
if (str[i] == ' ') {
continue;
}
if (str[8] == 'N') {
for (int j = 0;j < 10;j++) {
if (str[i] - '0' == nums[j]) {
nums[j] = -1;
}
}
}
else {
for (int j = 0;j < 10;j++) {
for (int k = 0;k < 7;k++) {
if (str[k] == ' ') {
continue;
}
if (nums[j] == str[k] - '0') {
break;
}
if (k == 6) {
nums[j] = -1;
}
}
}
}
}
}
/*
最初は0~9全てを持つ配列を用意する
その後、一列ごとに絞り込んだ内容を更新する
NO であればそこに含まれる数字はすべて除外
YES であればそこに含まれない数字は全て除外
*/
int main()
{
int nums[10] = {0,1,2,3,4,5,6,7,8,9};
int n = ReadNum();
for (int i = 0;i < n;i++) {//ターン数分ループして、絞り込みを毎回行う
ExtractNums(nums);
}
for (int i = 0;i < 10;i++) {
if (nums[i] != -1) {
printf("%d", nums[i]);
printf(" ");
}
}
}
subsn