1109 01組成的n的倍數
基準時間限制:1 秒 空間限制:131072 kb 分值: 40
難度:4級演算法題
給定乙個自然數n,找出乙個m,使得m > 0且m是n的倍數,並且m的10進製表示只包含0或1。求最小的m。
例如:n = 4,m = 100。
input
輸入1個數n。(1 <= n <= 10^6)output
輸出符合條件的最小的m。input示例
4output示例
10051nod-1109-01組成的n的倍數
思路:該題目用bfs+剪枝來求解,對於m,從最高位開始搜尋,判斷是否可整除;
#include#includeusing namespace std;
const int max_n=1000005;
struct node;
int n,ans;
vectorm;
bool book[max_n];
void bfs(void);
int main()
q.push_back();
int p=1;
while(l<=k&&p));
break;
}if(book[p]==false));
book[p]=true;
}} }
for(int i=k;i!=-1;i=q[i].nex)
m.push_back(q[i].x);
}
51 nod 1109 01組成的N的倍數
1109 01組成的n的倍數 基準時間限制 1 秒 空間限制 131072 kb 分值 40 難度 4級演算法題 給定乙個自然數n,找出乙個m,使得m 0且m是n的倍數,並且m的10進製表示只包含0或1。求最小的m。例如 n 4,m 100。input 輸入1個數n。1 n 10 6 output ...
51Nod 1109 01組成的N的倍數
題目鏈結 思路 一開始看的到這個題時,想都沒想直接乙個暴力上去了,結果很顯然。再後來做完後面的題,在回看這個題時,想到了廣搜。寫乙個簡單 沒剪枝 的廣搜,自己隨便測試一下,乙個9能測出來,然後直接就上了5個9,電腦直接宕機了 電腦效能太差 沒辦法啊!開機重啟,中間又花費了很多時間,我不死心,又重新測...
51nod 1109 01組成的N的倍數
01組成的n的倍數 給定乙個自然數n,找出乙個m,使得m 0且m是n的倍數,並且m的10進製表示只包含0或1。求最小的m。例如 n 4,m 100。input 輸入1個數n。1 n 10 6 output 輸出符合條件的最小的m。sample input4sample output100 解題思路 ...