結果

問題 No.793 うし数列 2
コンテスト
ユーザー takahiro-serikawa
提出日時 2019-05-07 23:18:28
言語 C90
(gcc 15.2.0)
コンパイル:
gcc-15 -O2 -std=c90 -DONLINE_JUDGE -o a.out _filename_ -lm
実行:
./a.out
結果
WA  
実行時間 -
コード長 293 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 170 ms
コンパイル使用メモリ 38,136 KB
最終ジャッジ日時 2026-02-24 01:03:12
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 3 WA * 18
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function 'main':
main.c:5:26: warning: integer overflow in expression of type 'int' results in '-1294967275' [-Woverflow]
    5 | #define MOD3(x) ((x) % (3*M))
      |                          ^
main.c:15:29: note: in expansion of macro 'MOD3'
   15 |                         n = MOD3(n * m);
      |                             ^~~~
main.c:5:26: warning: integer overflow in expression of type 'int' results in '-1294967275' [-Woverflow]
    5 | #define MOD3(x) ((x) % (3*M))
      |                          ^
main.c:16:21: note: in expansion of macro 'MOD3'
   16 |                 m = MOD3(m * m);
      |                     ^~~~

ソースコード

diff #
raw source code

#include <stdio.h>

#define M 1000000007
#define MOD(x) ((x) % M)
#define MOD3(x) ((x) % (3*M))

int main()
{
	long long N;
	scanf("%lld", &N);

	long long n = 1, m = 10;
	for ( ; N; N >>= 1) {
		if (N & 1)
			n = MOD3(n * m);
		m = MOD3(m * m);
	}
	printf("%lld\n", MOD(4*n/3));

	return 0;
}
0