結果

問題 No.739 大事なことなので2度言います
コンテスト
ユーザー Naoki00712
提出日時 2023-06-14 11:22:14
言語 C(gnu17)
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -std=gnu17 -Wno-error=implicit-function-declaration -Wno-error=implicit-int -Wno-error=incompatible-pointer-types -Wno-error=int-conversion -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 795 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 388 ms
コンパイル使用メモリ 39,364 KB
最終ジャッジ日時 2026-02-22 10:49:25
ジャッジサーバーID
(参考情報)
judge2 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 7
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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

int main()
{
	char* S, * front, * back;
	int len;

	S = (char*)malloc(sizeof(char) * 20);

	if (scanf("%s%n", S, &len) != 1) {
		return -1;
	}

	if (len%2 != 0) {
		printf("NO");
		return 0;
	}

	front = (char*)malloc(sizeof(char) * (len / 2) + 1);
	back = (char*)malloc(sizeof(char) * (len / 2) + 1);

	if (S == NULL || front == NULL || back == NULL) {
		return -1;
	}

	front[len / 2] = '\0';
	back[len / 2] = '\0';

	for (int i = 0; i < len; i++) {
		if (i < (len / 2)) {
			*(front + i) = *(S + i);
		}
		else {
			*(back + i - (len / 2)) = *(S + i);
		}
	}
	if (strcmp(front, back) != 0) {
		printf("NO");
		return 0;
	}

	printf("YES");

	free(S);
	free(front);
	free(back);

	S = NULL;
	front = NULL;
	back = NULL;

	return 0;
}
0