『Luogu OJ』『C++』Level 1-2

关卡1-2,3道题  顺序与分支

任务说明:计算机的智能性开始得以体现,因为计算机能够根据不同的条件选择了。

要完成这个任务,请将以下的题目都AC掉(即通过这道题目):

 

1.小玉家的电费 

2.不高兴的津津 

3.津津的储蓄计划

 

成就达成时间:2015-07-14 20:26

 

1.小玉家的电费 P1422

 

夏天到了,各家各户的用电量都增加了许多,相应的电费也交的更多了。小玉家今天收到了一份电费通知单。小玉看到上面写:据闽价电[2006]27号规定,月用电量在150千瓦时及以下部分按每千瓦时0.4463元执行,月用电量在151~400千瓦时的部分按每千瓦时0.4663元执行,月用电量在401千瓦时及以上部分按每千瓦时0.5663元执行;小玉想自己验证一下,电费通知单上应交电费的数目到底是否正确呢。请编写一个程序,已知用电总计,根据电价规定,计算出应交的电费应该是多少。

 

输入格式:
输入一个整数,表示用电总计(单位以千瓦时计),不超过10000。
输出格式:
输出一个数,保留到小数点后1位(单位以元计,保留到小数点后1位)。

 

就是这个题坑的我把C++ Primer一直看到了第六章……(hhhh)

然并卵……我还是bing到的如何保留小数……

作为一个cin cout党是多么不容易……

 

 1 #include<iostream>
 2 #include <iomanip>
 3 using namespace std;
 4 int main()
 5 {
 6     int w;
 7     cin>>w;
 8     if (w<150) 
 9       cout<<setiosflags(ios::fixed)<<setprecision(1)<<w*0.4463<<endl;
10     if ((w>=150) && (w<=400))
11        cout<<setiosflags(ios::fixed)<<setprecision(1)<<(w-150)*0.4663+66.945<<endl;
12     if (w>400) 
13        cout<<setiosflags(ios::fixed)<<setprecision(1)<<(w-400)*0.5663+183.52<<endl;
14   return 0;
15 }

想当年只要writeln(w:0:1)就完了……今天坑成这样……

不过话说回来了……这么cout才肉麻、嗯。

题水到无比,没啥好说的。

注意#include<iomanip>

 

 2.不高兴的津津  P1085

 

津津上初中了。妈妈认为津津应该更加用功学习,所以津津除了上学之外,还要参加妈妈为她报名的各科复习班。另外每周妈妈还会送她去学习朗诵、舞蹈和钢琴。但是津津如果一天上课超过八个小时就会不高兴,而且上得越久就会越不高兴。假设津津不会因为其它事不高兴,并且她的不高兴不会持续到第二天。请你帮忙检查一下津津下周的日程安排,看看下周她会不会不高兴;如果会的话,哪天最不高兴。

输入格式:
输入文件unhappy.in包括七行数据,分别表示周一到周日的日程安排。每行包括两个小于10的非负整数,用空格隔开,分别表示津津在学校上课的时间和妈妈安排她上课的时间。
输出格式:
输出文件unhappy.out包括一行,这一行只包含一个数字。如果不会不高兴则输出0,如果会则输出最不高兴的是周几(用1, 2, 3, 4, 5, 6, 7分别表示周一,周二,周三,周四,周五,周六,周日)。如果有两天或两天以上不高兴的程度相当,则输出时间最靠前的一天。

 

这题看着我都要乐哭了(并不是QiKu)

估计原来无聊的时候至少刷过5次……各种无聊算法

 

 1 #include<iostream> 
 2 using namespace std;
 3 int main()
 4 {
 5     int School, After_School;
 6     int hrs,Day,hours;
 7     Day=0;
 8     hours=8;
 9     for (int i=0;i<=6;++i)
10     {
11        cin>>School>>After_School;
12        hrs=School+After_School;
13        if (hrs>hours) 
14          {
15              Day=i+1;
16              hours=hrs;
17          }
18     }
19     cout<<Day<<endl;
20   return 0;    
21 }

可惜无缘见我的Pascal各种奇葩版……rqnoj vijos tyvj什么鬼肯定有好多版,hhhhh

3.津津的储蓄计划 P1089

津津的零花钱一直都是自己管理。每个月的月初妈妈给津津300元钱,津津会预算这个月的花销,并且总能做到实际花销和预算的相同。 

    为了让津津学习如何储蓄,妈妈提出,津津可以随时把整百的钱存在她那里,到了年末她会加上20%还给津津。因此津津制定了一个储蓄计划:每个月的月初,在得到妈妈给的零花钱后,如果她预计到这个月的月末手中还会有多于100元或恰好100元,她就会把整百的钱存在妈妈那里,剩余的钱留在自己手中。 

    例如11月初津津手中还有83元,妈妈给了津津300元。津津预计11月的花销是180元,那么她就会在妈妈那里存200元,自己留下183元。到了11月月末,津津手中会剩下3元钱。 

    津津发现这个储蓄计划的主要风险是,存在妈妈那里的钱在年末之前不能取出。有可能在某个月的月初,津津手中的钱加上这个月妈妈给的钱,不够这个月的原定预算。如果出现这种情况,津津将不得不在这个月省吃俭用,压缩预算。 

    现在请你根据2004年1月到12月每个月津津的预算,判断会不会出现这种情况。如果不会,计算到2004年年末,妈妈将津津平常存的钱加上20%还给津津之后,津津手中会有多少钱。

 

输入格式:
输入文件save.in包括12行数据,每行包含一个小于350的非负整数,分别表示1月到12月津津的预算。
输出格式:
输出文件save.out包括一行,这一行只包含一个整数。如果储蓄计划实施过程中出现某个月钱不够用的情况,输出-X,X表示出现这种情况的第一个月;否则输出到2004年年末津津手中会有多少钱。

 

想想那时候NOIp多和谐……尤其是2004的样例,hhhhh

这题同样是乐哭了的(hhh)

 1 #include<iostream> 
 2 using namespace std;
 3 int main()
 4 {
 5     int money=0;
 6     int jj=0;
 7     int mom=0;
 8   for (int i=0;i<=11;++i)
 9     {
10         cin>>money;
11         jj+=(300-money);
12         if (jj<0)
13           {
14               cout<<"-"<<i+1<<endl;
15               return 0;
16               exit;
17           }          
18         if (jj>=100)
19           {
20            int tmp=((jj/100)*100);
21            mom+=tmp;
22            jj-=tmp;
23           }
24     }
25     cout<<mom*1.2+jj<<endl;
26   return 0;    
27 }

我竟然沦落到写这种脑残题

hhhhh

嗯,+= -还挺好玩的吧

posted @ 2015-07-14 20:36  Iris.Catch-22.S、`  阅读(345)  评论(0编辑  收藏  举报