zoukankan      html  css  js  c++  java
  • 牛客第二场Dmoney

    链接:https://www.nowcoder.com/acm/contest/140/D
    来源:牛客网
    
    题目描述 
    White Cloud has built n stores numbered from 1 to n.
    White Rabbit wants to visit these stores in the order from 1 to n.
    The store numbered i has a price a[i] representing that White Rabbit can spend a[i] dollars to buy a product or sell a product to get a[i] dollars when it is in the i-th store.
    The product is too heavy so that White Rabbit can only take one product at the same time.
    White Rabbit wants to know the maximum profit after visiting all stores.
    Also, White Rabbit wants to know the minimum number of transactions while geting the maximum profit.
    Notice that White Rabbit has infinite money initially.
    输入描述:
    The first line contains an integer T(0<T<=5), denoting the number of test cases.
    In each test case, there is one integer n(0<n<=100000) in the first line,denoting the number of stores.
    For the next line, There are n integers in range [0,2147483648), denoting a[1..n].
    输出描述:
    For each test case, print a single line containing 2 integers, denoting the maximum profit and the minimum number of transactions.
    示例1
    输入
    复制
    1
    5
    9 10 7 6 8
    输出
    复制
    3 4

    贪心。下一家店变贵了手里没有拿就买。下一家店便宜了,手里有货就卖出。

     1 #include <iostream>
     2 #include <string>
     3 #include <cstring>
     4 #include <iomanip>
     5 #include <cmath>
     6 #include <cstdlib>
     7 #include <cstdio>
     8 #include <algorithm>
     9 #include <map>
    10 #include <queue>
    11 #include <vector>
    12 #include <set>
    13 #include <stack>
    14 using namespace std;
    15 #define ll long long
    16 int a[100005];
    17 int main()
    18 {
    19     int T;
    20     scanf("%d",&T);
    21     while(T--)
    22     {
    23         int m;
    24         scanf("%d",&m);
    25         for(int i=1;i<=m;i++)
    26         {
    27             scanf("%d",&a[i]);
    28         }
    29         ll flag=0;
    30         ll ans=0;
    31         ll  mo=0;
    32         a[m+1]=0;
    33         for(int i=1;i<=m;i++)
    34         {
    35             if(a[i]<a[i+1]&&flag==0)
    36             {
    37                 flag=1;
    38                 ans++;
    39                 mo=mo-a[i];
    40             }
    41             else
    42             {
    43                 if(flag==1&&a[i]>a[i+1])
    44                 {
    45                     ans++;
    46                     flag=0;
    47                     mo=mo+a[i];
    48                 }
    49             }
    50         }
    51         cout<<mo<<" "<<ans<<endl;
    52 
    53     }
    54     return 0;
    55 }
  • 相关阅读:
    使用树莓派打造一个音乐播放器
    关于ESP8266 NodeCMU固件无法刷入新代码的解决方法
    推荐一个好用的免费开源的笔记本软件CherryTree
    忘记数据库密码?通过Navicat找回!!
    Kettle删除日志文件
    windows下解决10点前生成时间命名的文件无效问题
    windows下备份Linux服务器上的MySQL
    Windows下安装mysql
    【EXCEL】按天计算,分摊到每年的费用金额,只用内置函数 无需编写VB
    windows 7 安装visual studio 2019 闪退问题解决
  • 原文地址:https://www.cnblogs.com/2014slx/p/9370097.html
Copyright © 2011-2022 走看看