結果
| 問題 | No.782 マイナス進数 |
| コンテスト | |
| ユーザー |
rickytheta
|
| 提出日時 | 2019-01-11 22:13:58 |
| 言語 | C++11 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 7 ms / 2,000 ms |
| コード長 | 684 bytes |
| 記録 | |
| コンパイル時間 | 875 ms |
| コンパイル使用メモリ | 180,420 KB |
| 実行使用メモリ | 7,976 KB |
| 最終ジャッジ日時 | 2026-05-23 23:59:23 |
| 合計ジャッジ時間 | 2,191 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 36 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
#define REP(i,n) for(int i=0;i<(int)(n);i++)
int t,b;
int main(){
scanf("%d%d",&t,&b);
b = -b;
while(t--){
int n;
scanf("%d", &n);
if(n==0){
puts("0"); continue;
}
string s;
while(n){
int c = n%b;
if(c<0)c+=b;
if(s.size()%2==0){
s += string(1,'0'+c);
n -= c;
}else{
c = (b-c)%b;
s += string(1,'0'+c);
n += c;
}
n /= b;
}
reverse(s.begin(), s.end());
puts(s.c_str());
}
return 0;
}
rickytheta