根据条件选择不同路线,就要用到分支结构,下面通过一个例题来说明。
洛谷P1423:有一只小鱼,它平日每天游泳 250 公里,周末休息(实行双休日),假设从周 x(1≤x≤7) 开始算起,过了 n(n≤10^6) 天以后,小鱼一共累计游泳了多少公里呢?
| 输入 | 输出 |
| 3 10 | 2000 |
这里需要判断周x是否为周末,来决定游泳/休息。可以对每一天进行判断;也可以去掉整周,只判断剩余的天数。采用一个数组d[8]记录剩余的天数,星期是1到7,大于7时需要循环回来;考虑数据的范围,int能够满足要求,程序如下。
#include<iostream>
using namespace std;
int main() {
int x,n,d[8]={0},ans;
cin>>x>>n;
for(int i=1;i<=n%7;i++){
//记录剩余天是星期几
if((x+i-1)<=7)d[x+i-1]=1;
else //超过7要循环回1-7
d[x+i-1-7]=1;
}
//工作日游泳
ans=n/7*5*250+(d[1]+d[2]+d[3]+d[4]+d[5])*250;
cout<<ans;
return 0;
}
本文通过一个关于小鱼游泳里程计算的编程题目,介绍了如何使用分支结构处理不同条件下的逻辑选择。示例展示了如何根据日期判断小鱼是否在工作日游泳,并通过数组记录剩余天数,最终计算累计游泳距离。

被折叠的 条评论
为什么被折叠?



