一道简单的套路题,假设有两头牛a,b,这两头牛交换位置不影响前面的情况和后面的情况,因为无论怎么交换,他们的时间消耗总和都是一样的,可以推导出:当满足ta/da<=tb/db时,a牛在前的情况更优,所以按上述推导的公式从小到大排序,n处的结果就是最后答案。看这个题的数据比较大,又需要乘法,所以判断需不需要高精度,判断以后发现sum的最大值只能是10^13次方,long long可以装下。

#include<iostream>
#include<algorithm>
using namespace std;
int n;
const int M = 1e5 + 5;
struct node {
	long long t, d;
	double div;
	bool operator<(const node& p)const {
		return div < p.div;
	}
}a[M];
long long T[M];
long long sum[M];
int main() {
	cin >> n;
	for (int i = 1; i <= n; i++) {
		cin >> a[i].t >> a[i].d;
		a[i].div = (double)a[i].t / (double)a[i].d;
	}
	sort(a + 1, a + 1 + n);

	for (int i = 1; i <= n; i++) {
		T[i] = T[i - 1] + 2 * a[i].t;	//时间 
	}

	for (int i = 1; i <= n; i++) {
		sum[i] = sum[i - 1] + a[i].d * T[i - 1];
	}
	cout << sum[n] << endl;
	return 0;
}