藍橋杯 演算法訓練 2的次冪表示(遞迴演算法)

2021-10-07 11:58:46 字數 1554 閱讀 1272

問題描述

任何乙個正整數都可以用2進製表示,例如:137的2進製表示為10001001。

將這種2進製表示寫成2的次冪的和的形式,令次冪高的排在前面,可得到如下表示式:137=2^7 +2^3 +2^0

現在約定冪次用括號來表示,即a^b表示為a(b)

此時,137可表示為:

2(7)+2(3)+2(0)

進一步:7=2^2 +2+2^0 (2^1用2表示)

3=2+2^0

所以最後137可表示為:

2(2(2)+2+2(0))+2(2+2(0))+2(0)

又如:1315=2^10 +2^8 +2^5+2+1

所以1315最後可表示為:

2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

輸入格式

正整數(1<=n<=20000)

輸出格式

符合約定的n的0,2表示(在表示中不能有空格)

樣例輸入

137樣例輸出

2(2(2)+2+2(0))+2(2+2(0))+2(0)

樣例輸入

1315

樣例輸出

2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

遞迴簡介:

遞迴是一種數學上分而自治的思想。

a、將原問題分解為規模較小的問題進行處理

分解後的問題與原問題型別完全相同,當規模較小。

通過小規模問題的解,能夠輕易求得原生問題的解

b、問題的分解時有限的

當邊界條件不能滿足時,分解問題(繼續遞迴)

當邊界條件滿足時,直接求解(遞迴結束)

這題不難看出是乙個遞迴問題

比如137可表示為:2(7)+2(3)+2(0)

但是這裡7和3不滿足題目要求的格式,這時候子問題就是把7和3化為題目要求的格式,和原問題型別完全相同,所以就可以再次呼叫遞迴,

7=2(2)+2+2(0)

3=2+2(0)

此時137=2(2(2)+2+2(0))+2(2+2(0))+2(0)

這個時候就都滿足題目要求了,就可以停止遞迴了。

所以,每次遞迴的時候,就對遞迴過程中產生的數進行乙個判斷,把不滿足格式的數字繼續遞迴下去,直到滿足格式即可。

上**:

#include

using

namespace std ;

void

digui

(int num )

for(

--i , j = i ; i >=0;

--i )}}

}int

main()

這道題總的來說比較簡單,注意一下細節就能ac了,也算是當做遞迴入門訓練很好的一道練手題。

衝衝衝!

藍橋杯 演算法訓練 2的次冪表示(遞迴)

這個遞迴挺難得,湊合看懂 任何乙個正整數都可以用2進製表示,例如 137的2進製表示為10001001。將這種2進製表示寫成2的次冪的和的形式,令次冪高的排在前面,可得到如下表示式 137 2 7 2 3 2 0。現在約定冪次用括號來表示,即a b表示為a b 此時,137可表示為 2 7 2 3 ...

藍橋杯 演算法訓練 2的次冪表示

問題描述 任何乙個正整數都可以用2進製表示,例如 137的2進製表示為10001001。將這種2進製表示寫成2的次冪的和的形式,令次冪高的排在前面,可得到如下表示式 137 2 7 2 3 2 0 現在約定冪次用括號來表示,即a b表示為a b 此時,137可表示為 2 7 2 3 2 0 進一步 ...

藍橋杯 演算法訓練 2的次冪表示

問題描述 任何乙個正整數都可以用2進製表示,例如 137的2進製表示為10001001。將這種2進製表示寫成2的次冪的和的形式,令次冪高的排在前面,可得到如下表示式 137 2 7 2 3 2 0 現在約定冪次用括號來表示,即a b表示為a b 此時,137可表示為 2 7 2 3 2 0 進一步 ...