题目描述
听说郑州紫荆山公园有英语口语角,还有很多外国人呢。为了和老外对上几句,这周六早晨birdfly拉上同伴早早的就坐上了72路公交从学校向紫荆山进发。一路上没事干,birdfly开始思考一个问题。
从学校到紫荆山公园共有n(1<=n<=20)站路,birdfly刚上车时车上有m个人,每到一站都有pi个人上车,qi个人下车,问这一路上公车上最多有多少人。(0<=m, pi ,qi <=50).
输入:输入有多组样例,每组样例第一行两个数n m,接下来n行每行两个数pi和qi。
输出:每组实例输出这一路上(包含上车站点和下车站点)公交车上最多的人数。每组实例输出占一行。
样例输入 Copy
2 3 5 2 3 5
样例输出 Copy
6
程序代码
#include<stdio.h>
int main()
{
int n,m;//n为学校到紫荆山公园的公交站的总数,m为birdfly刚上车时车上的人数
while(scanf("%d%d",&n,&m)!=EOF)//利用while循环进行多实例测试
{
int pi,qi;//定义每站上车的人数和每站下车的人数
int max=m;//定义一个max表示车上人最多时的数量
int sum=m;//sum负责计算每次到站后车上人数的实时变化
while(n--)
{
scanf("%d%d",&pi,&qi);
sum=sum+pi-qi;
if(max<sum)//当车上人数变多时,将最多的人数赋值给max
max=sum;
}
printf("%d\n",max);//最后输出最大的max值
}
return 0;
}