結果

問題 No.64 XORフィボナッチ数列
ユーザー tatuyan_edsontatuyan_edson
提出日時 2015-05-22 00:25:56
言語 C90
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 318 bytes
コンパイル時間 105 ms
コンパイル使用メモリ 21,504 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-07-06 04:24:53
合計ジャッジ時間 584 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
6,812 KB
testcase_01 AC 1 ms
6,944 KB
testcase_02 AC 1 ms
6,940 KB
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 AC 0 ms
6,940 KB
testcase_13 WA -
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: In function ‘main’:
main.c:17:15: warning: format ‘%u’ expects argument of type ‘unsigned int’, but argument 2 has type ‘long long unsigned int’ [-Wformat=]
   17 |   printf("%I64u\n",ans);
      |           ~~~~^    ~~~
      |               |    |
      |               |    long long unsigned int
      |               unsigned int
      |           %I64llu
main.c:7:3: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    7 |   scanf("%Lu%Lu%Lu",&F0,&F1,&N);
      |   ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#include<stdio.h>

int main(void){
  unsigned long long F0,F1,N,ans=0;
  unsigned long long i,j,k;

  scanf("%Lu%Lu%Lu",&F0,&F1,&N);

  for(i=0;i<64;i++){
    j=(F0>>i)&1;
    k=(F1>>i)&1;
    if(j)
      ans+=(k?(N%3!=2):(N%3!=1))<<i;
    else
      ans+=(k?(N%3!=0):0)<<i;
  }
  printf("%I64u\n",ans);

  return 0;
}
0