結果

問題 No.2187 三立法和 mod 333
ユーザー SSRS
提出日時 2023-01-13 21:28:34
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
TLE  
実行時間 -
コード長 783 bytes
コンパイル時間 1,925 ms
コンパイル使用メモリ 172,476 KB
実行使用メモリ 9,344 KB
最終ジャッジ日時 2024-12-24 16:30:11
合計ジャッジ時間 7,263 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other TLE * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
int main(){
  int A;
  cin >> A;
  vector<int> M(4444);
  for (int i = 0; i < 4444; i++){
    M[i] = (long long) i * i * i % 333;
  }
  vector<long long> Q(4445);
  for (int i = 1; i <= 4444; i++){
    Q[i] = (long long) i * i * i * i;
  }
  vector<vector<int>> S(333, vector<int>(4445, 0));
  for (int i = 0; i < 333; i++){
    for (int j = 0; j < 4444; j++){
      S[i][j + 1] = S[i][j];
      if (j > 0 && M[j] == i){
        S[i][j + 1]++;
      }
    }
  }
  long long ans = 0;
  for (int i = 1; i < 4444; i++){
    int k = 4443;
    for (int j = 1; Q[i] + Q[j] < Q[4444]; j++){
      while (Q[i] + Q[j] + Q[k] > Q[4444]){
        k--;
      }
      ans += S[(A - M[i] - M[j] + 666) % 333][k + 1];
    }
  }
  cout << ans << endl;
}
0