当前位置: 首页 > news >正文

河南手机网站建设公司排名企业qq多少钱一年

河南手机网站建设公司排名,企业qq多少钱一年,建设网站需要注意什么,一个dede管理两个网站一家新的餐馆开业了,为了吸引更多的顾客,每样餐品都有打折的活动。特别的,餐馆内一共有𝑛样菜品,编号从 1 1 1 到 n n n,每样菜品每人最多只能点一次。对于第 i i i 种菜品,其包含两种价格&a…

一家新的餐馆开业了,为了吸引更多的顾客,每样餐品都有打折的活动。特别的,餐馆内一共有𝑛样菜品,编号从 1 1 1 n n n,每样菜品每人最多只能点一次。对于第 i i i 种菜品,其包含两种价格:活动价格 a i a_i ai 与差价 b i b_i bi

假设某顾客点了 k k k 样菜品,依次编号为 p 1 , … , p k p_1,\dots,p_k p1,,pk,那么最终需要支付的价格为
∑ i = 1 k a p i + max ⁡ i = 1 k b p i \sum\limits_{i=1}^ka_{p_i}+\max_{i=1}^kb_{p_i} i=1kapi+i=1maxkbpi

现在有 n n n 名顾客光顾这家餐馆,第 i i i 名顾客想恰好点 i i i 样菜品,请帮助每位顾客计算出他的最小花费。

n ≤ 2 × 1 0 5 n\le2\times10^5 n2×105


先把菜品按 b b b 从小到大排序,如果当前要点 k k k 个菜,选定第 i i i 个菜,那么就是要在前 i − 1 i-1 i1 个菜中选 k − 1 k-1 k1 个菜。

可以用 set 维护,或者主席树,时间复杂度 O ( n 2 log ⁡ n ) O(n^2\log n) O(n2logn),这是暴力。

w ( k , i ) w(k,i) w(k,i) 表示前 i i i 个菜中选 k k k 个菜的最小花费, f ( k ) f(k) f(k) 为使 w ( k , i ) w(k,i) w(k,i) 取得最小值的 i i i

考虑决策 x < y x<y x<y,若 w ( k , x ) ≥ w ( k , y ) w(k,x)\ge w(k,y) w(k,x)w(k,y),增大 k k k y y y 可选的菜品比 x x x 的多,所以 ∀ k ′ ∈ ( k , n ] , w ( k ′ , x ) ≥ w ( k ′ , y ) \forall k'\in(k,n],w(k',x)\ge w(k',y) k(k,n],w(k,x)w(k,y),若 y = f ( k ) y=f(k) y=f(k),则对于后面的决策点 m m m w w w 值至少都比前面的要小了,所以 f ( k ) ≤ f ( m ) f(k)\le f(m) f(k)f(m),即 f ( 1 ) ≤ f ( 2 ) ≤ ⋯ ≤ f ( n ) f(1)\le f(2)\le\dots\le f(n) f(1)f(2)f(n),决策具有单调性。

如果这是 DP,就可以用 1D/1D 动态规划的优化方法 O ( n log ⁡ n ) O(n\log n) O(nlogn) 拿下。但是这不是。

这里要用分治的思想,函数 s o l v e ( l , r , L , R ) solve(l,r,L,R) solve(l,r,L,R) 表示当前处理到区间 [ l , r ] [l,r] [l,r] m i d mid mid 的最优决策点在 L , R L,R L,R。每次暴力求出 p o s = f ( m i d ) pos=f(mid) pos=f(mid),把问题分成 s o l v e ( l , m i d − 1 , L , p o s ) solve(l,mid-1,L,pos) solve(l,mid1,L,pos) s o l v e ( m i d + 1 , r , p o s , R ) solve(mid+1,r,pos,R) solve(mid+1,r,pos,R) 两部分,这样递归处理下去。

求一个 w w w O ( log ⁡ V ) O(\log V) O(logV) 的,总的时间复杂度为 O ( n log ⁡ n log ⁡ V ) O(n\log n\log V) O(nlognlogV)。( V V V 是值域)

代码如下

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll INF=1e18,Inf=1e9;
const int N=2e5+1;
int n,A[N],cnt,rt[N];
ll ans[N];
struct node
{int a,b;bool operator<(const node &a)const{return b<a.b;}
}a[N];
struct Node
{int ls,rs,sz;ll sum;
}tr[N*32];
void insert(int &rt,int la,int l,int r,int x)
{rt=++cnt;tr[rt]=tr[la];tr[rt].sz++;tr[rt].sum+=x;if(l==r) return;int mid=l+r>>1;if(x<=mid) insert(tr[rt].ls,tr[la].ls,l,mid,x);else insert(tr[rt].rs,tr[la].rs,mid+1,r,x);
}
ll query(int rt,int l,int r,int k)
{if(l==r) return k*l;int mid=l+r>>1,sum=tr[tr[rt].ls].sz;if(sum>=k) return query(tr[rt].ls,l,mid,k);else return query(tr[rt].rs,mid+1,r,k-sum)+tr[tr[rt].ls].sum;
}
void solve(int l,int r,int L,int R)
{if(r<l) return;int mid=l+r>>1,pos;ll sum=INF;for(int i=max(mid,L);i<=R;i++){ll x=a[i].b+a[i].a+query(rt[i-1],0,Inf,mid-1);if(sum>x){sum=x;pos=i;}}ans[mid]=sum;solve(l,mid-1,L,pos);solve(mid+1,r,pos,R);
}
int main()
{freopen("order.in","r",stdin);freopen("order.out","w",stdout);scanf("%d",&n);for(int i=1;i<=n;i++) scanf("%d%d",&a[i].a,&a[i].b);sort(a+1,a+1+n);for(int i=1;i<=n;i++) insert(rt[i],rt[i-1],0,Inf,a[i].a);solve(1,n,1,n);for(int i=1;i<=n;i++) printf("%lld\n",ans[i]);
}
http://www.hkea.cn/news/104085/

相关文章:

  • 用别人公司域名做网站线下推广的渠道和方法
  • php mysql的网站开发外贸推广平台
  • 济南网站建设认可搜点网络能百度指数有三个功能模块
  • 网上商城网站建设意义在线代理浏览网页
  • 网站图片切换代码百度下载并安装最新版
  • 微信公众平台号申请注册入口杭州seo公司
  • 本周实时热点新闻事件seo文章代写一篇多少钱
  • 旺店通app手机企业版下载网站seo如何优化
  • 宝山区建设用地事务所网站网络公司有哪些
  • 用sql做简单的博客网站大连谷歌seo
  • 新手怎么学做网站就业培训机构有哪些
  • magento网站建设搭建网站步骤
  • 营销网站如何实现差异化南京seo公司
  • 服务器托管是啥搜索引擎优化排名培训
  • 山西手机网站建设网址大全123
  • b2c平台有哪些平台网址新区seo整站优化公司
  • WordPress突然全站404网站如何添加友情链接
  • 复制别人网站做第一站seo短视频网页入口引流下载
  • 基层建设论文收录在哪个网站百度统计api
  • 购买主机可以做网站吗楚雄今日头条新闻
  • 深圳专业网站建设公司哪家好宁波网络营销公司
  • ps做电商网站流程图百度图片识别搜索引擎
  • 做电影网站程序好用武汉网站建设推广公司
  • 如何做b2c网站下列关于友情链接说法正确的是
  • 网站开发中网页上传seo在线网站推广
  • 网站建设报价流程免费培训网站
  • 聊城网站建设服务好最新网域查询入口
  • 一般网站建设流程有哪些步骤官方百度app下载安装
  • 档案网站建设的步骤八大营销方式有哪几种
  • 手机网站免费制作平台semseo