結果

問題 No.3157 Nabeatsu
コンテスト
ユーザー pengin_2000
提出日時 2025-05-23 19:23:36
言語 C
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
AC  
実行時間 5 ms / 2,000 ms
コード長 470 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 144 ms
コンパイル使用メモリ 40,768 KB
最終ジャッジ日時 2026-02-22 13:37:19
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 45
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function 'main':
main.c:25:25: warning: writing 1 byte into a region of size 0 [-Wstringop-overflow=]
   25 |                 s[n - 1]--;
      |                 ~~~~~~~~^~
main.c:2:6: note: at offset -1 into destination object 's' of size 1000006
    2 | char s[1000006];
      |      ^

ソースコード

diff #
raw source code

#include<stdio.h>
char s[1000006];
int main()
{
	scanf("%s", s);
	int i, j, n;
	for (n = 0; s[n] != '\0'; n++);
	for (;;)
	{
		for (i = 0; i < n && s[i] != '3'; i++);
		if (i < n)
		{
			s[i]--;
			for (j = i + 1; j < n; j++)
				s[j] = '9';
		}
		int sum = 0;
		for (i = 0; i < n; i++)
			sum += s[i] - '0';
		if (sum % 3 > 0)
		{
			printf("%s\n", s);
			break;
		}
		s[n - 1]--;
		for (i = n - 1; s[i] < '0'; i--)
		{
			s[i] += 10;
			s[i - 1]--;
		}
	}
	return 0;
}
0