洛谷 P1023 税收与补贴问题 (2000NOIP提高组)

题意分析

一开始没理解题意。啰啰嗦嗦一大堆。看了别人的题解才明白啥意思。

对于样例来说,简而言之:

首先可以根据题目推算出来

28 130

29 125

30 120

31 110

32 95

33 80

34 65

35 50

36 35

37 20

38 5

表示在某个金额时的销量。在金钱为39的时候,销量为负数,肯定是不能盈利的。

我们假设题目所求的补贴/收税金额为x(正数表示补贴,负数表示收税),那么题目要求我们算出绝对值最小的x,使得下列不等式均成立。

(31-28 + x) * 110 >= (28 - 28 + x) * 130

(31-28 + x) * 110 >= (29 - 28 + x) * 125

(31-28 + x) * 110 >= (30 - 28 + x) * 120

(31-28 + x) * 110 >= (31 - 28 + x) * 110

(31-28 + x) * 110 >= (32 - 28 + x) * 95

……

(31-28 + x) * 110 >= (38 - 28 + x) * 5

说白了,就是让商家在政府制定的价格时盈利最多,那么商家肯定愿意在那个价格卖。那么问题就是如何求出这个x。

其实如果算出来每个价格对应的销量之后,那么我们只需要求解下面的方程,一定可以解除min<=x<=max。然后就可以找到x绝对值最小的数。

并且根据政府期望商家卖的价钱分为两部分,第一部分求得最小值,第二部分求得最大值,即可。

代码总览

#include <bits/stdc++.h>
#define nmax
using namespace std;
typedef struct item{
int Price;
int Sales;
}item;
int GovPrice = 0;
int Cost = 0, SalesAtCost = 0,TargetSales = 0;
int TempPrice = 0, TempSales = 0;
int DecreaseMount = 0;
vector<item> v;
bool cmp(item a, item b)
{
return a.Price<b.Price;
}
void PricePocess()
{
int tag = v.size();
int gapNum,gapDec;
item head,tail;
for(int i = 0;i<tag-1;++i){
head = v[i];
tail = v[i+1];
gapNum = tail.Price - head.Price;
if(gapNum == 1) continue;
else{
gapDec = (tail.Sales - head.Sales) / gapNum;
int Temp = head.Sales;
for(int j = 1;j<gapNum;++j){
Temp+=gapDec;
v.push_back({head.Price+j,Temp});
}
}
}
sort(v.begin(),v.end(),cmp);
tag = v.size();
TempPrice = v[tag-1].Price;
TempSales = v[tag-1].Sales;
while(1){
TempPrice++;
TempSales-=DecreaseMount;
if(TempPrice<=0 || TempSales<=0) break;
else{
v.push_back({TempPrice,TempSales});
}
}
}
int main()
{ //freopen("in.txt","r",stdin);
v.clear();
scanf("%d",&GovPrice);
scanf("%d %d",&Cost,&SalesAtCost);
v.push_back({Cost,SalesAtCost});
while(scanf("%d %d",&TempPrice,&TempSales)){
if(TempPrice == -1 && TempSales == -1) break;
item temp = {TempPrice,TempSales};
v.push_back(temp);
}
scanf("%d",&DecreaseMount);
sort(v.begin(),v.end(),cmp);
PricePocess();
sort(v.begin(),v.end(),cmp);
int PriceTag = -1;
for(int i=0;i<v.size();++i){
//printf("%d %d\n",v[i].Price,v[i].Sales);
if(v[i].Price == GovPrice){
PriceTag = i;
TargetSales = v[i].Sales;
break;
}
}
if(PriceTag == -1){
printf("NO SOLUTION\n");
return 0;
}else{
int MoneyForOne = GovPrice - Cost;
double LimitMax = 100000000 ,LimitMin = -1000000000;
for(int i = 0;i<PriceTag;++i){
double TempLimit = 1.0 * (MoneyForOne * TargetSales - ((v[i].Price-Cost)*v[i].Sales) ) / (v[i].Sales - TargetSales);
LimitMax = min(TempLimit,LimitMax);
}
for(int i = PriceTag+1;i<v.size();++i){
double TempLimit = 1.0 * ((v[i].Price-Cost)*v[i].Sales - MoneyForOne * TargetSales ) / (TargetSales - v[i].Sales);
LimitMin = max(TempLimit,LimitMin);
}
int ans = 0;
//printf("%f %f\n",LimitMin,LimitMax);
if(LimitMin > LimitMax){
printf("NO SOLUTION\n");
return 0;
}else if(LimitMin > 0){
if(fabs((LimitMin) - (int)(LimitMin)) > 1e-6) ans = (int)LimitMin + 1;
else ans = (int)LimitMin;
}else if(LimitMax < 0){
if(fabs((LimitMax) - (int)(LimitMax)) > 1e-6) ans = (int)LimitMax - 1;
else ans = (int)LimitMax;
}
printf("%d\n",ans);
}
return 0;
}

洛谷 P1023 税收与补贴问题 (2000NOIP提高组)的更多相关文章

  1. 洛谷——P1023 税收与补贴问题

    P1023 税收与补贴问题 题目背景 每样商品的价格越低,其销量就会相应增大.现已知某种商品的成本及其在若干价位上的销量(产品不会低于成本销售),并假设相邻价位间销量的变化是线性的且在价格高于给定的最 ...

  2. 洛谷P1023 税收与补贴问题

    P1023 税收与补贴问题 题目背景 每样商品的价格越低,其销量就会相应增大.现已知某种商品的成本及其在若干价位上的销量(产品不会低于成本销售),并假设相邻价位间销量的变化是线性的且在价格高于给定的最 ...

  3. 洛谷 P1023 税收与补贴问题

    P1023 税收与补贴问题 题目背景 每样商品的价格越低,其销量就会相应增大.现已知某种商品的成本及其在若干价位上的销量(产品不会低于成本销售),并假设相邻价位间销量的变化是线性的且在价格高于给定的最 ...

  4. [NOIP2000] 提高组 洛谷P1023 税收与补贴问题

    题目背景 每样商品的价格越低,其销量就会相应增大.现已知某种商品的成本及其在若干价位上的销量(产品不会低于成本销售),并假设相邻价位间销量的变化是线性的且在价格高于给定的最高价位后,销量以某固定数值递 ...

  5. 洛谷p1017 进制转换(2000noip提高组)

    洛谷P1017 进制转换 题意分析 给出一个数n,要求用负R进制显示. n∈[-32768,32767].R ∈[-20,-2] 考察的是负进制数的转换,需要理解短除法. 看到这道题的时候,我是比较蒙 ...

  6. Java实现 洛谷 P1023 税收与补贴问题

    import java.util.Scanner; public class Main { public static void main(String[] args){ Scanner in = n ...

  7. 洛谷-求同构数的个数-NOIP2013提高组复赛

    题目描述 Description 所谓同构数是指这样的数,即它出现在它的平方数的右端.例如,5的平方是25 (即5×5=25),5是25右端的数,那么5就是同构数.又如,25的平方是625(即25×2 ...

  8. 洛谷-谁拿了最多奖学金-NOIP2005提高组复赛

    题目描述 Description 某校的惯例是在每学期的期末考试之后发放奖学金.发放的奖学金共有五种,获取的条件各自不同: 1)     院士奖学金,每人8000元,期末平均成绩高于80分(>8 ...

  9. 洛谷 1328 生活大爆炸版石头剪刀布(NOIp2014提高组)

    [题解] 简单粗暴的模拟题. #include<cstdio> #include<algorithm> #include<cstring> #define LL l ...

随机推荐

  1. scrapy 爬取知乎问题、答案 ,并异步写入数据库(mysql)

      python版本  python2.7 爬取知乎流程: 一 .分析 在访问知乎首页的时候(https://www.zhihu.com),在没有登录的情况下,会进行重定向到(https://www. ...

  2. JAVA Date、String、Calendar类型之间的转化

    1.Calendar 转化 String //获取当前时间的具体情况,如年,月,日,week,date,分,秒等 Calendar calendat = Calendar.getInstance(); ...

  3. div不设置高度背景颜色或外边框不能显示的解决方法

    在使用div+css进行网页布局时,如果外部div有背景颜色或者边框,而不设置其高度,在浏览时出现最外层Div的背景颜色和边框不起作用的问题. 大体结构<div class="oute ...

  4. UVa 10071

    简单运动学公式 v=v0+at x=v0t+1/2*a*t^2=2vt #include<stdio.h> int main() { int v, t; while((scanf(&quo ...

  5. loadrunner socket协议问题归纳(5)

    获取服务器的返回值,可以用web_reg_save_param函数,该参数最好放到: 语法: int web_reg_save_param(const char *ParamName, <lis ...

  6. 王者荣耀交流协会final发布版本控制报告

    二次开发软件说明文档 Dec 6 纠正饼状图点击选择PSP文件无效. 添加饼状图丢失的代码. submit the files that last night I forgot. add shurum ...

  7. 【探路者】团队互评Alpha版本

    [探路者]组互评连接: 1互评作品:SkyHunter http://www.cnblogs.com/zej87/p/7802000.html 2互评作品:爱阅app http://www.cnblo ...

  8. c# Application.run和form.show区别

    Application.run(form):在当前线程上开始运行标准应用程序消息循环,并使指定窗体可见. form.show() :使指定窗体可见: 参照:https://blog.csdn.net/ ...

  9. 第一次c++作业(感觉不是很好系列)

    日常先贴github的地址 https://github.com/egoistor/Elevator-scheduling 然后我觉得学习了半天,构造函数似懂非懂(用的是class自动生成的构造函数, ...

  10. Alpha冲刺——第五天

    Alpha第五天 听说 031502543 周龙荣(队长) 031502615 李家鹏 031502632 伍晨薇 031502637 张柽 031502639 郑秦 1.前言 任务分配是VV.ZQ. ...