【bzoj3119】【book】【贪心】

Description

Wayne喜欢看书,更喜欢买书。
某天Wayne在当当网上买书,买了很多很多书。Wayne有一个奇怪的癖好,就是第一本书的价格必须恰为X,而之后买的每一本书,若是比上一本更昂贵,则价格最多多A元;若是比上一本更便宜,则价格最多少B元。
Wayne心血来潮,一口气买了N本书,但他记不得每本书的价格了,只记得总价格是M。Wayne于是很想知道一种可能的书价分布。为了简化问题,我们假定书价的定义域是整数,且每本书与上一本书的价格差,要么恰为+A,要么恰为-B。
只要给出任意一个合法的书价序列就算正确。

Input

第一行一个正整数N。
第二行四个整数依次是X,A,B,M。

Output

输出一行N个整数,用空格隔开。数据保证有解。

Sample Input

4
10 1 2 37

Sample Output

10 11 9 7

HINT

【数据规模和约定】

对于5%的数据,满足N = 1。

对于另外25%的数据,满足A = B = 1, N <= 100。

对于另外10%的数据,满足A, B <= 5, N <= 100。

对于另外20%的数据,满足N <= 1000。

对于100%的数据,满足1 <= A, B <= 10^6,|X| <= 10^6,N <= 10^5,M可用带符号64位整型存储。 

题解:

          设最后的和中加了x次,减了y次。

          则

               Ax+By+n*x0=M;

               x+y=n*(n-1)/2;

          把x,y解出来贪心选择即可。

代码:

#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
int n;
ll num,m,x0,a,b,x,y,c;
int main(){
  scanf("%d",&n);
  for (int i=1;i<n;i++) num+=(ll)i;
  scanf("%lld%lld%lld%lld",&x0,&a,&b,&m);
  c=(ll)(m-(ll)n*x0);x=(c+b*num)/(a+b);y=num-x;
  printf("%lld ",x0);n--;
  while (n){
    if (x>=n) x0+=a,x-=n;else x0-=b,y-=n;
    n--;printf("%lld",x0);if (n!=0) printf(" ");
  }
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值