zoukankan      html  css  js  c++  java
  • HDU5477(模拟)

    A Sweet Journey

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)
    Total Submission(s): 975    Accepted Submission(s): 504


    Problem Description

    Master Di plans to take his girlfriend for a travel by bike. Their journey, which can be seen as a line segment of length L, is a road of swamps and flats. In the swamp, it takes A point strengths per meter for Master Di to ride; In the flats, Master Di will regain B point strengths per meter when riding. Master Di wonders:In the beginning, he needs to prepare how much minimum strengths. (Except riding all the time,Master Di has no other choice) 

     

    Input

    In the first line there is an integer t (1t50), indicating the number of test cases.
    For each test case:
    The first line contains four integers, n, A, B, L.
    Next n lines, each line contains two integers: Li,Ri, which represents the interval [Li,Ri] is swamp.
    1n100,1L105,1A10,1B101Li<RiL.
    Make sure intervals are not overlapped which means Ri<Li+1 for each i (1i<n).
    Others are all flats except the swamps.
     

    Output

    For each text case:
    Please output “Case #k: answer”(without quotes) one line, where k means the case number counting from 1, and the answer is his minimum strengths in the beginning.
     

    Sample Input

    1
    2 2 2 5
    1 2
    3 4
     

    Sample Output

    Case #1: 0
     

    Source

     
     1 //2016.9.13
     2 #include <iostream>
     3 #include <cstdio>
     4 #define N 105
     5 
     6 using namespace std;
     7 
     8 int main()
     9 {
    10     int T, kase = 0, ans, n, a, b, len, l[N], r[N];
    11     scanf("%d", &T);
    12     while(T--)
    13     {
    14         int tmp = 0;
    15         ans = 0;//假设最初需要0点能量
    16         scanf("%d%d%d%d", &n, &a, &b, &len);
    17         l[0] = r[0] = 0;
    18         for(int i = 1; i <= n; i++)
    19         {
    20             scanf("%d%d", &l[i], &r[i]);
    21             tmp = tmp+b*(l[i]-r[i-1])-a*(r[i]-l[i]);
    22             if(ans > tmp)ans = tmp;
    23         }
    24         printf("Case #%d: %d
    ", ++kase, -ans);
    25     }
    26 
    27     return 0;
    28 }
  • 相关阅读:
    windows系统历年高危漏洞
    安全产品分类
    防火墙
    UTM(统一威胁管理)
    ORA-39127: 调用 "WMSYS"."LT_EXPORT_PKG"."SCHEMA_INFO_EXP" 时发生意外错误
    oracle如何查看当前有哪些用户连接到数据库
    LINUX修改主机名
    删除Oracle用户及表空间
    Oracle AWR报告详细分析--比较详细
    RMAN优缺点及RMAN备份及恢复步骤
  • 原文地址:https://www.cnblogs.com/Penn000/p/5869974.html
Copyright © 2011-2022 走看看