对于每一个代理。
我们直接模拟就行了,看看是A方案好还是B方案好。
细节参见代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int INF = 100000000;
const int maxn = 100 + 5 ;
int T,n,m,l,kase = 0;
struct node{
char name[20];
int a,b,cost;
bool operator < (const node& rhs) const {
return cost < rhs.cost || (cost == rhs.cost && strcmp(name,rhs.name)<0);
}
}a[maxn];
char s[100];
int main() {
scanf("%d",&T);
while(T--) {
scanf("%d%d%d",&n,&m,&l);
for(int i=0;i<l;i++) {
scanf("%s",s);
int len = strlen(s), res ;
for(int j=0;j<len;j++) {
if(s[j] == ':') { res = j+1; a[i].name[j] = '\0'; break; }
else a[i].name[j] = s[j];
}
a[i].a = a[i].b = 0;
for(int j=res;j<len;j++) {
if(s[j] == ',') { res = j+1; break; }
else a[i].a = a[i].a*10 + s[j] - '0';
}
for(int j=res;j<len;j++)
a[i].b = a[i].b*10 + s[j] - '0';
}
for(int i=0;i<l;i++) {
a[i].cost = 0;
int cur = n;
while(true) {
int v = round(cur*1.0/2);
if(cur - v < m) {
a[i].cost += a[i].a*(cur - m); break;
}
if(v * a[i].a < a[i].b) {
a[i].cost += a[i].a*(cur - m); break;
}
else {
cur -= v;
a[i].cost += a[i].b;
}
}
}
sort(a,a+l);
printf("Case %d\n",++kase);
for(int i=0;i<l;i++)
printf("%s %d\n",a[i].name,a[i].cost);
}
return 0;
}

本文介绍了一个用于模拟不同代理的成本计算算法。通过输入特定参数,如代理名称、成本阈值等,该算法能够评估两种方案(A和B)下每个代理的成本,并据此进行排序。文章提供了一段C++代码实现,详细展示了如何解析输入数据、计算成本及排序输出结果。
1093

被折叠的 条评论
为什么被折叠?



