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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

杭电2013-蟠桃记(C++)

發布時間:2023/12/1 c/c++ 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 杭电2013-蟠桃记(C++) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Problem Description
喜歡西游記的同學肯定都知道悟空偷吃蟠桃的故事,你們一定都覺得這猴子太鬧騰了,其實你們是有所不知:悟空是在研究一個數學問題!
什么問題?他研究的問題是蟠桃一共有多少個!
不過,到最后,他還是沒能解決這個難題,呵呵-
當時的情況是這樣的:
第一天悟空吃掉桃子總數一半多一個,第二天又將剩下的桃子吃掉一半多一個,以后每天吃掉前一天剩下的一半多一個,到第n天準備吃的時候只剩下一個桃子。聰明的你,請幫悟空算一下,他第一天開始吃的時候桃子一共有多少個呢?

Input
輸入數據有多組,每組占一行,包含一個正整數n(1<n<30),表示只剩下一個桃子的時候是在第n天發生的。

Output
對于每組輸入數據,輸出第一天開始吃的時候桃子的總數,每個測試實例占一行。

Sample Input
2
4

Sample Output
4
22

思路分析:

若是吃到第一天,還剩一個桃子,則一共1個桃子 若是吃到第二天,還剩一個桃子,則一共4個桃子(1+3) 若是吃到第三天,還剩一個桃子,則一共10個桃子(4+3*2) 若是吃到第四天,還剩一個桃子,則一共22個桃子(10+12*2) 若是吃到第五天,還剩一個桃子,則一共46個桃子(22+24*2) ...... 由此可知,第二天剩一個桃子,是在第一天的基礎上+3 第三天剩一個桃子,是在第二天的基礎上+2*3 第四天剩一個桃子,是在第三天的基礎上+(2*3) * 2 第五天剩一個桃子,是在第四天的基礎上+(2*3*2)* 2 ......、

代碼如下:

#include <iostream> using namespace std;int main() {int a[50]= {0,1,4};int x,b;while(cin>>x){b=3;//基數for(int i=1; i<=x; i++){a[i+1]=a[i]+b;//每次都是在前一天桃子數上加上基數b*=2;//每次加的基數會翻倍}cout<<a[x]<<endl;}return 0; }

總結

以上是生活随笔為你收集整理的杭电2013-蟠桃记(C++)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。