結果

問題 No.3 ビットすごろく
ユーザー smiken_61smiken_61
提出日時 2015-10-23 15:06:41
言語 C++11
(gcc 11.4.0)
結果
WA  
実行時間 -
コード長 881 bytes
コンパイル時間 818 ms
コンパイル使用メモリ 68,168 KB
実行使用メモリ 6,948 KB
最終ジャッジ日時 2024-07-22 11:31:50
合計ジャッジ時間 2,037 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
6,812 KB
testcase_01 AC 2 ms
6,940 KB
testcase_02 AC 2 ms
6,944 KB
testcase_03 AC 2 ms
6,940 KB
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 2 ms
6,940 KB
testcase_13 AC 2 ms
6,940 KB
testcase_14 AC 2 ms
6,944 KB
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 AC 2 ms
6,944 KB
testcase_22 WA -
testcase_23 AC 3 ms
6,944 KB
testcase_24 WA -
testcase_25 WA -
testcase_26 AC 1 ms
6,940 KB
testcase_27 WA -
testcase_28 WA -
testcase_29 WA -
testcase_30 AC 2 ms
6,944 KB
testcase_31 AC 2 ms
6,944 KB
testcase_32 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <algorithm>
#include <stdlib.h>
#include <string>
#include <queue>
using namespace std;


int b(int a){
int k=0;
for(int y=0;y<8;y++){
if(a&1 == 1 ) k=k+1;
a=a >> 1;
}
return k;
}


int main() {
queue<pair<int,int> > q; //iti,kaisuu
int n;
int ch[100000]={0};
ch[1]=1;
pair<int,int> z;
cin>>n;
q.push(make_pair(1,1));
int ans=-1;
int kaisuu=-1,ichi;
while(q.size() != 0){
z=q.front();
 ichi=z.first;
kaisuu=z.second;
if(ichi==n) {
ans=kaisuu;
break;
}
if(0< ichi+b(ichi) && ichi+b(ichi) <n+1){
if(ch[ichi+b(ichi)]==0) {
q.push(make_pair(ichi+b(ichi),kaisuu+1));
ch[ichi+b(ichi)]=1;
}
//cout<<ichi+b(ichi)<<" "<<kaisuu+1<<endl;
}

if(0< ichi-b(ichi) && ichi-b(ichi) <n+1){
if(ch[ichi-b(ichi)]==0) {
q.push(make_pair(ichi-b(ichi),kaisuu+1));
ch[ichi-b(ichi)]=1;
}
//cout<<ichi-b(ichi)<<" "<<kaisuu+1<<endl;
}
q.pop();


}



cout<<ans<<endl;

return 0;
}
0