【问题描述】
村里刚刚通网,小芳非常激动,下载了很多文件。她的网络使用情况如下: 在最开始的 T1 分钟内,下载速度是 D1 MB/min;接下来的 T2 分钟内,下载速度是 D2 MB/min;以此类推,最后 TN 分钟内,下载速度是 DN MB/min。 互联网运营商的收费标准是,先免费提供 K 分钟的网络使用,之后每 MB 数据收取 1 元费用。请你算出小芳需要付多少网费。
【输入形式】
输入数据的第一行包含一个整数 T,表示测试数据的组数。接下来是 T 组数据。 每组数据的第一行包含两个整数 N 和 K。接下来 N 行,每行包含两个整数 Ti 和 Di,描述了小芳的网络使用状况。
【输出形式】
对于每组数据,输出一行,包含一个整数,代表小芳需要付的网费,单位为元
【样例输入】
3
2 2
2 1
2 3
2 2
1 2
2 3
3 0
1 2
2 4
10 10
【样例输出】
6
3
110
【样例说明】
对于第一组数据,小芳只需要付后 2 分钟的网费,每分钟 3元,共 6元。
对于第二组数据,小芳只需要付最后 1 分钟的网费 3 元。
对于第三组数据,运营商没有提供免费时长,因此小芳需要付 1×2 + 2×4 + 10×10 = 110元。
#include<iostream>
using namespace std;
int main()
{
int t,n,k,ti,di; //定义组数t,数据数n,免费时间k
cin>>t;
int cha,time1=0,time2=0; //差值cha,time1,time2
for(int i=1;i<=t;i++) //测试组数的循环
{
cin>>n>>k;
cha=0,time1=0,time2=0; //每次循环过后要重新归零
for(int x=1;x<=n;x++) //测试数据的输入
{
cin>>ti>>di;
time1=time1+ti; //time1为到现在的时间总长
if(time1<=k) cha=0; //time1小于免费时间则差为零
else
{
//time2为此时间段之前的时间段的时间总长
if(time1>k&&time2<=k) cha=cha+(time1-k)*di;
//time1超出免费时间,而time2未超,差值=差值加超出的时间*下载速度
else cha=cha+ti*di;
//time1,2均超出时,差值=差值+此时间段*下载速度
}
time2=time2+ti; //time2加上此时间段
}
cout<<cha<<endl;
//因为付款为每MB1元,所以输出MB即可
}
return 0;
}