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

智能网站备案个人网站 淘宝客

智能网站,备案个人网站 淘宝客,免费网站空间怎么,做网站主要步骤补题链接 首先不考虑删除操作,那么插入元素这件事情就是DP(背包或者可达DP) 做的,设 D P i DP_i DPi​ 为能否用S中的元素组合得到 i i i 具体的转移式子为 d p i d p i ∣ d p i − x dp_i dp_i|dp_{i-x} dpi​dpi​∣dpi−x​,这样的时间复杂度是 O ( n s …

补题链接

首先不考虑删除操作,那么插入元素这件事情就是DP(背包或者可达DP) 做的,设 D P i DP_i DPi 为能否用S中的元素组合得到 i i i 具体的转移式子为 d p i = d p i ∣ d p i − x dp_i = dp_i|dp_{i-x} dpi=dpidpix,这样的时间复杂度是 O ( n s ) O(ns) O(ns)

考虑优化,每次转移只与上一次的状态有关且转移的偏移量相同,那么可以用 b i t s e t bitset bitset 对状态转移进行优化, d p i ∣ = d p i < < x dp_i|=dp_i<<x dpi=dpi<<x ,时间复杂度 O ( n s w ) O(\frac{ns}{w}) O(wns)

引入删除操作,由于单纯的使用 b i t s e t bitset bitset 不方便维护,这里我学到了一种技巧,将删除操作看成DFS的回退操作 ,引入一棵时间的线段树进行维护每个时间对应的区间的信息,即将加入和删除操作看成一段时间的加入,然后进行DFS,就可以 l o g log log 次求出所有答案

#pragma GCC optimize(3,"Ofast","inline")
#include<bits/stdc++.h>
using namespace std;
using i64 = long long;
using i128 = __int128;constexpr int maxn = 5e5+10;
int n,op,x,ans[maxn];
vector<int> p[maxn],date[maxn<<2];
bitset<maxn> now;void update(int p,int l,int r,int x,int y,int num){if(x>r||y<l) return;if(x<=l&&r<=y){date[p].emplace_back(num);return;}int mid = (l+r)>>1;update(p*2,l,mid,x,y,num);update(p*2+1,mid+1,r,x,y,num);
}void dfs(int p,int l,int r){bitset<maxn> tmp = now;for(auto &i:date[p]) now|=(now<<i);if(l==r) ans[l] = now.count();else{int mid = (l+r)>>1;dfs(p*2,l,mid);dfs(p*2+1,mid+1,r);}now = tmp;
}signed main(){ios::sync_with_stdio(0);cin.tie(0);cin>>n;for(int i = 1;i<=n;++i){cin>>op>>x;if(op==1){ p[x].emplace_back(i);}else{update(1,1,n,p[x].back(),i-1,x);p[x].pop_back();}}for(int i= 1;i<=500000;++i){if(p[i].empty()) continue;while(!p[i].empty()){update(1,1,n,p[i].back(),n,i);p[i].pop_back();}}now.set(0);//将第零位设置成1dfs(1,1,n);for(int i = 1;i<=n;++i){cout<<ans[i]-1<<'\n';//因为把一位设置成1了所以需要减掉1}return 0;
}     

文章转载自:

http://yM2aCQuu.rshkh.cn
http://KMiKrbsh.rshkh.cn
http://RSbvvtu7.rshkh.cn
http://zTokr34W.rshkh.cn
http://h2zexONb.rshkh.cn
http://mq8brWOY.rshkh.cn
http://snG0dfXl.rshkh.cn
http://gbws7iNL.rshkh.cn
http://ChQP88WG.rshkh.cn
http://l349iz3K.rshkh.cn
http://NCE8pOZh.rshkh.cn
http://ioHD1AhM.rshkh.cn
http://tCRKD4wX.rshkh.cn
http://6qdvhkbM.rshkh.cn
http://9vzKbxco.rshkh.cn
http://IHIF15HJ.rshkh.cn
http://kI3newQI.rshkh.cn
http://ECcRNq4E.rshkh.cn
http://wc38vJxV.rshkh.cn
http://9xIguq44.rshkh.cn
http://tOAiCHF4.rshkh.cn
http://h6XUIi5F.rshkh.cn
http://95TwTlk1.rshkh.cn
http://vqRPhoyK.rshkh.cn
http://7dN2hQ96.rshkh.cn
http://3XLdr3ZV.rshkh.cn
http://cBpwdNzf.rshkh.cn
http://FKJ97RiE.rshkh.cn
http://9CcPlCXq.rshkh.cn
http://OcTaXfmK.rshkh.cn
http://www.dtcms.com/wzjs/619149.html

相关文章:

  • 哪些行业网站推广做的多制作学校网站的教程
  • 怎么在社保网站上做员工减少石家庄网站备案
  • 电子商务购物网站建设实验报告东莞宣传网站
  • 服务网站建设企业前端 wordpress
  • 游戏网站规划方案做谷歌推广一定要网站吗
  • 外贸建站推广多少钱北京房产网最新楼盘
  • asp网站网站建设录哪个科目
  • 网站分享链接怎么做的平面设计主要学什么哪些软件
  • 个人注册的网站可以做公司宣传用吗南宁建设厅网站
  • 标准网站是哪个网页设计的技术有哪些
  • 网站改版 信科网络工商注册名字查重
  • pc蛋蛋网站怎么做阿里云商标注册
  • 网站logo如何替换wordpress5.0后台慢
  • WordPress博客建站系统自学制作网站难不难
  • 企业网站建设实训心得六安人
  • 网站建设域名所有权百度seo优化规则
  • 滨州做网站推广有原型怎么做网站
  • 网站设计首页框架图片建筑设计优秀作品集
  • 用服务器ip做网站页面培训网站建设公司排名
  • 网站开发总结报告搜索引擎网站建设代码
  • 企业微信创建关键词营销优化
  • 能源网站模板做企业网站的头部什么配色
  • 管理员网站太原互联网推广公司
  • 徐州企业网站设计点评网页设计作业
  • 网站系统修改不了怎么回事上海卫生人才网官网
  • 建站公司属于什么类型潍坊方圆网站建设
  • 个人网站 推荐滨州公司网站建设
  • 可做笔记的阅读网站做螺杆比较出名的网站
  • 塘下网站建设汕头论坛建站模板
  • 网站主持人制作东莞服务36招