超市抢购
该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。
题目描述
封城咯。大爷大妈大叔大姨们抓紧时间抢购咯。
超市里一共有种商品,第种商品的储量是,需求量是。
然而需求未必都能满足,比如,牙刷的储量是2,需求量是3,饼干的储量是3,需求量是2,这样,牙刷就不够用。
于是,膜法师开始对超市的购物者们施法了,每使用1点法力,就可以使1件第种商品,变成第种商品。
比如在上面的例子中,牙刷编号是1,饼干编号是2,膜法师可以花费1的法力,把1个饼干变成牙刷,这样问题就解决了。
现在,请帮助膜法师算一下,他最少需要花多少的法力,可以使得所有需求都被满足?
输入格式
第一行输入两个整数,表示商品种类数,数据生成种子。
数组将由如下代码生成:
int a[maxn],b[maxn];
int randseed;
unsigned int rnd()
{
unsigned int r;
r = randseed = randseed * 1103515245 + 12345;
return (r << 16) | ((r >> 16) & 0xFFFF);
}
int main()
{
cin>>n>>randseed;
int sum=0;
for (int i=n;i>=1;i--)
{
a[i]=rnd()%1000,b[i]=rnd()%1000;
if (sum+(a[i]-b[i])<0) swap(a[i],b[i]);
sum+=(a[i]-b[i]);
}
}
输出格式
一个整数,表示答案,数据保证有解。
样例输入
10 998244353
___________两组样例之间的分割线________________
100 114514
样例输出
700
___________两组样例之间的分割线________________
106509
数据规模与约定
对于的数据:。
对于的数据:。
对于的数据: