日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

信息学奥赛一本通(1208:2的幂次方表示)

發(fā)布時(shí)間:2025/3/17 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 信息学奥赛一本通(1208:2的幂次方表示) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1208:2的冪次方表示


時(shí)間限制: 1000 ms ??? ??? 內(nèi)存限制: 65536 KB
提交數(shù): 5891 ??? 通過數(shù): 4389

【題目描述】

任何一個(gè)正整數(shù)都可以用2的冪次方表示。例如:

137=27+23+20

同時(shí)約定方次用括號(hào)來表示,即ab可表示為a(b)。由此可知,137可表示為:

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

進(jìn)一步:7=22+2+20(21用2表示)

3=2+20

所以最后137可表示為:

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

又如:

1315=210+28+25+2+1

所以1315最后可表示為:

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

【輸入】

一個(gè)正整數(shù)n(n≤20000)。

【輸出】

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

【輸入樣例】

137

【輸出樣例】

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

【分析】

? ? ? ? 137=2(7)+2(3)+2(1)

? ? ? ? 分為兩個(gè)部分,一個(gè)是2(7);另一個(gè)是+2(3)+2(1)

? ? ? ? 第一個(gè)部分,先求循環(huán)求r=7,然后,遞歸求f(7),即2(7)

? ? ? ? 第二個(gè)部分,求其余部分,即 +2(3)+2(1)

【參考代碼】

#include<stdio.h> #include<math.h> void f(int n) {int r=0,other;while((int)pow(2,r)<=n){r++;}r--;if(r==0)printf("2(0)");else if(r==1)printf("2");else{printf("2(");f(r);printf(")");}other=n-pow(2,r);if(other){printf("+");f(other);} } int main() {int n;scanf("%d",&n);f(n);printf("\n");return 0; }

http://ybt.ssoier.cn:8088/problem_show.php?pid=1208

?

總結(jié)

以上是生活随笔為你收集整理的信息学奥赛一本通(1208:2的幂次方表示)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。