結果

問題 No.1047 Zero (Novice)
ユーザー YugimnYugimn
提出日時 2022-05-11 01:39:49
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 1,158 bytes
コンパイル時間 1,909 ms
コンパイル使用メモリ 186,808 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-07-18 08:25:20
合計ジャッジ時間 2,773 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 17
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp:9:12: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
    9 | void print(auto a){
      |            ^~~~
main.cpp:13:13: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
   13 | void prints(auto a){
      |             ^~~~
main.cpp:21:13: warning: use of 'auto' in parameter declaration only available with '-std=c++20' or '-fconcepts'
   21 | void printl(auto a){
      |             ^~~~

ソースコード

diff #

//Normal

#define _GLIBCXX_DEBUG
#define ll long long
#include <bits/stdc++.h>
using namespace std;
using Graph = vector<vector<int>>;

void print(auto a){
  cout << a;
}

void prints(auto a){
  cout << a << " ";
}

void prints(){
  cout << " ";
}

void printl(auto a){
  cout << a << endl;
}

void printl(){
  cout << endl;
}

void fix(int n){
  cout << fixed << setprecision(n);
}

int siz(string s){
  return (int)s.size();
}

int main(){
  ll A, B; cin >> A >> B;

  if(B == 0){
    printl(1);

    return 0;
  }

  ll X1 = B;
  ll X2 = A*X1 + B;

  if(X2 == 0){
    printl(2);

    return 0;
  }
  
  if(X2 > X1){
    if(X2 < 0){
      for(int i = 3; ; i++){
        ll X = A*X2 + B;

        if(X == 0){
          printl(i);

          return 0;
        }else if(X > 0){
          printl(-1);

          return 0;
        }

        X2 = X;
      }
    }
  }else if(X2 < X1){
    if(X2 > 0){
      for(int i = 3; ; i++){
        int X = A*X2 + B;

        if(X == 0){
          printl(i);

          return 0;
        }else if(X < 0){
          printl(-1);

          return 0;
        }

        X2 = X;
      }
    }
  }

  printl(-1);

  return 0;
}
0