結果

問題 No.294 SuperFizzBuzz
ユーザー bal4ubal4u
提出日時 2019-08-06 05:57:22
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 115 ms / 5,000 ms
コード長 797 bytes
コンパイル時間 1,265 ms
コンパイル使用メモリ 28,940 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-25 17:37:11
合計ジャッジ時間 2,216 ms
ジャッジサーバーID
(参考情報)
judge11 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,376 KB
testcase_01 AC 1 ms
4,376 KB
testcase_02 AC 115 ms
4,380 KB
testcase_03 AC 1 ms
4,376 KB
testcase_04 AC 0 ms
4,380 KB
testcase_05 AC 1 ms
4,380 KB
testcase_06 AC 1 ms
4,376 KB
testcase_07 AC 1 ms
4,380 KB
testcase_08 AC 6 ms
4,380 KB
testcase_09 AC 73 ms
4,380 KB
testcase_10 AC 1 ms
4,380 KB
testcase_11 AC 94 ms
4,376 KB
testcase_12 AC 103 ms
4,380 KB
testcase_13 AC 109 ms
4,376 KB
testcase_14 AC 115 ms
4,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

// yukicoder: No.294 SuperFizzBuzz
// 2019.8.6 bal4u

#include <stdio.h>

// 32ビット用
int bitcount(int bits) {
    bits = (bits & 0x55555555) + (bits >> 1 & 0x55555555);
    bits = (bits & 0x33333333) + (bits >> 2 & 0x33333333);
    bits = (bits & 0x0f0f0f0f) + (bits >> 4 & 0x0f0f0f0f);
    bits = (bits & 0x00ff00ff) + (bits >> 8 & 0x00ff00ff);
    return (bits & 0x0000ffff) + (bits >>16 & 0x0000ffff);
}

int a[] = {0,0,1,3,6,11,21,42,85,171,342,683,1365,2730,5461,
10923,21846,43691,87381,174762,349525,699051,1398102,2796203,5592405};

char s[32];
int main()
{
	int i, k, w, N;
	
	scanf("%d", &N);
	for (w = 0; N > a[w]; w++) N -= a[w];
	i = 1; while (N) if (bitcount(++i) % 3 == 2) N--;
	k = 30, s[--k] = '5';
	while (w--) s[--k] = (i & 1)? '5': '3', i >>= 1;
	puts(s+k);
	return 0;
}
0