[枚舉]P1089 津津的儲蓄計劃

津津的儲蓄計劃

題目描述
津津的零花錢一直都是自己管理。每個月的月初媽媽給津津300元錢,津津會預算這個月的花銷,並且總能做到實際花銷和預算的相同。

爲了讓津津學習如何儲蓄,媽媽提出,津津可以隨時把整百的錢存在她那裏,到了年末她會加上20%還給津津。因此津津制定了一個儲蓄計劃:每個月的月初,在得到媽媽給的零花錢後,如果她預計到這個月的月末手中還會有多於100元或恰好100元,她就會把整百的錢存在媽媽那裏,剩餘的錢留在自己手中。

例如11月初津津手中還有83元,媽媽給了津津300元。津津預計11月的花銷是180元,那麼她就會在媽媽那裏存200元,自己留下183元。到了11月月末,津津手中會剩下3元錢。

津津發現這個儲蓄計劃的主要風險是,存在媽媽那裏的錢在年末之前不能取出。有可能在某個月的月初,津津手中的錢加上這個月媽媽給的錢,不夠這個月的原定預算。如果出現這種情況,津津將不得不在這個月省喫儉用,壓縮預算。

現在請你根據2004年1月到12月每個月津津的預算,判斷會不會出現這種情況。如果不會,計算到2004年年末,媽媽將津津平常存的錢加上20%還給津津之後,津津手中會有多少錢。

輸入格式
1212行數據,每行包含一個小於350的非負整數,分別表示11月到1212月津津的預算。

輸出格式
一個整數。如果儲蓄計劃實施過程中出現某個月錢不夠用的情況,輸出-X−X,XX表示出現這種情況的第一個月;否則輸出到20042004年年末津津手中會有多少錢。

注意,洛谷不需要進行文件輸入輸出,而是標準輸入輸出。

輸入輸出樣例

輸入 #1
290
230
280
200
300
170
340
50
90
80
200
60

輸出 #1
-7

輸入 #2
290
230
280
200
300
170
330
50
90
80
200
60

輸出 #2
1580

題目解析
先讀數,判斷每個月的支出會不會超過剩餘的錢;如果超過的就輸出“-月份”(不用加引號),如果剩餘的錢超過100就存起來,年底就*1.2取出。

AC完整程序

#include<cstdio>
int main(){
	int a[12],s=0,k=0,zh=0,i,e=0;
	for(i=0;i<=11;i++){
		scanf("%d",&a[i]);
	}
	    for(i=0;i<=11;i++){
		    s+=300;
	        if(a[i]>s){
			    printf("%d",(i+1)*(-1));
		        return 0;
		    }
		    s-=a[i];
		    if(s>=100){
		    	k=s/100*100;
		        s-=k;
				e+=k;
			}
	    }
	zh+=e*6/5;zh+=s;
	printf("%d",zh);
	return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章