const double eps = 1e-6;
struct Candy {
int v; int w;
bool operator < (const Candy & c) //刚学++,看不懂这里
{ return double(v)/w - double(c.v)/c.w > eps; }
} candies[110];
int main() {
int n, w;
scanf("%d%d", &n, &w);
for(int i = 0; i < n; ++i)
scanf("%d%d", &candies[i].v, &candies[i].w);
sort(candies, candies+n); //这是排序的一步
line4代码的意思是重载“<”运算符号,使之能比较Candy结构提的大小,具体的比较逻辑就是Line5的代码