填空题B-工程检修

填空题B-工程检修

时间: 1ms        内存:128M

描述:

注:本题只需要提交标记为修改部分之间的代码,请按照C++方式提交。

某工程检修小组,约定向东为正。乘一辆汽车从A地出发到收工时,行走的记录为:
  +15,-2,+5,-1,+10,-3 ,-2 ,+12 , +4 ,-5 ,-6
求该小组在工作时,最远离出发地多远?

#include <iostream>
using namespace std;
int main()
{
    int maxDistance=0,relative,sum=0;
    int i,n;
    cin>>n;
    for(i=0; i<n; i++)
    {
        cin>>relative;
        sum+=relative;
        if(sum>0)
        {
            if(maxDistance<sum)
                maxDistance=sum;
        }
        else
        {
            /*
                请填写该部分代码
            */

        }
    }
    cout<<maxDistance<<endl;
    return 0;
}

输入:

n 和 n 条行走记录

输出:

离出发地最远距离

示例输入:

11
+15 -2 +5 -1 +10 -3 -2 +12 +4 -5 -6

示例输出:

38

提示:

参考答案(内存最优[1484]):


#include <iostream>
using namespace std;
int main()
{
    int maxDistance=0,relative,sum=0;
    int i,n;
    cin>>n;
    for(i=0; i<n; i++)
    {
        cin>>relative;
        sum+=relative;
        if(sum>0)
        {
            if(maxDistance<sum)
                maxDistance=sum;
        }
        else
        {
if(-sum>maxDistance)
				maxDistance=-sum;
        }
    }
    cout<<maxDistance<<endl;
    return 0;
}

参考答案(时间最优[0]):


#include <iostream>
using namespace std;
int main()
{
    int maxDistance=0,relative,sum=0;
    int i,n;
    cin>>n;
    for(i=0; i<n; i++)
    {
        cin>>relative;
        sum+=relative;
        if(sum>0)
        {
            if(maxDistance<sum)
                maxDistance=sum;
        }
        else
        {
            if(maxDistance<-sum)
                maxDistance=-sum;
        }
    }
    cout<<maxDistance<<endl;
    return 0;
}

题目和答案均来自于互联网,仅供参考,如有问题请联系管理员修改或删除。

点赞

发表评论

电子邮件地址不会被公开。必填项已用 * 标注