C語言- 喝汽水,1瓶汽水1元,2個空瓶可以換一瓶汽水,給20元,可以多少汽水?__C語言

來源:互聯網
上載者:User

喝汽水,1瓶汽水1元,2個空瓶可以換一瓶汽水,給20元,可以多少汽水。編程實現。

整體思路:用遞迴的方式實現,每一次遞迴表示本次可以購買汽水的瓶數(M)。首先判斷M是否是能夠全部兌換完(M為偶數),分兩種情況:

如果可以(M為偶數),再次進行 M/2 的遞迴,表示本次M個瓶子兌換 M/2 個汽水;

如果不可以(M為奇數),在這裡我們進行一個判斷(flag:看在本次兌換之前的兌換中是否有多餘的一個空瓶子,初值為0),如果flag為0(沒有多餘的),那麼本次兌換留下一個空瓶子,即flag=1(本次留下一個不進行兌換),以供下次兌換使用;如果flag為1,那麼本次兌換,加上這個瓶子,進行兌換,即flag=0,表示之前留下的空瓶子已被用掉。

直到 2*M + flag 小於2,不能再兌換為止。

代碼實現(Visual Studio 2017)

//喝汽水,1瓶汽水1元,2個空瓶可以換一瓶汽水,給20元,可以多少汽水。編程實現。#include<stdio.h>#include<windows.h>int Buysoda(int M){    static int flag = 0;//flag作為一個判斷,看在本次兌換之前的兌換中是否有多餘的一個瓶蓋    if (2 * M + flag < 2) //判斷能否購買汽水    {        return 0;    }    if (M % 2 == 0)//M瓶汽水的瓶蓋是偶數,本次兌換剛好換完    {        return M + Buysoda(M / 2);    }    else if (M % 2 == 1 && flag == 0)//M瓶汽水的瓶蓋是奇數,且沒有多餘的瓶蓋,留下一個瓶蓋,剩下的全部兌換    {        flag = 1;//表示本次兌換剩下一個瓶蓋,提供下次兌換        return M + Buysoda(M / 2);    }    else if (M % 2 == 1 && flag == 1)//M瓶汽水的瓶蓋是奇數,且有多餘的瓶蓋,加上這個瓶蓋一起兌換    {        flag = 0;//之前的瓶蓋已被用掉        return M + Buysoda(M / 2  + 1);    }}int main(){    int money = 20;    int num = 0;    num = Buysoda(money);    printf("可以買 %d 瓶汽水\n", num);    system("pause");    return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.