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

电商网站需求分析什么值得买 网站开发

电商网站需求分析,什么值得买 网站开发,网站功能定制,属于建设工程合同的有哪些传送门:CF 题目描述: 题目较长,此处省略 输入: 3 3 2 1 2 3 1 4 2 5 1 1 1 1 1 10 10 4 6 9 12 16 20 2 10 19 7 1 3 5 4 2 17 2 18 6 11 7 1 8 17 5 5 5 5 2 2 输出: 13 1 705比赛的时候感觉已经想到了正解,但是没有想的很清楚,所以赛时没有打出来. 我认为这道题的突破口其…

传送门:CF

题目描述:

题目较长,此处省略
输入:
3
3 2
1 2 3
1 4
2 5
1 1
1
1 1
10 10
4 6 9 12 16 20 2 10 19 7
1 3
5 4
2 17
2 18
6 11
7 1
8 17
5 5
5 5
2 2
输出:
13
1
705

比赛的时候感觉已经想到了正解,但是没有想的很清楚,所以赛时没有打出来.

我认为这道题的突破口其实是在ai<=n+ma_i<=n+mai<=n+m这里的.有了这个,所以我们最终的算法能够不是n2n^2n2,但是赛时我甚至没有注意到这一点(笑

对于每一个数组中的一个数字来说,我们考虑计算这个数字在其他所有数组中的贡献.我们会发现当这个数字不在其他数组中的时候,显然我们可以得到一个贡献,但是当我们的这个数字在其他数组中的时候,我们此时的这个数字在这个数组中是没有贡献的.我们可以先假装这个数字在其他数组中是没有的,那么此时我们的总贡献就是m∗(1+m)/2m*(1+m)/2m(1+m)/2(一共有m+1个数组).但是我们此时可能有一种情况就是有重复数字的贡献,所以我们考虑将这个重复数字的贡献减掉.我们可以计算出在所有m+1m+1m+1个数组中这个数字的个数cntcntcnt,那么对于所有的数组来说,我们之前所重复计算的就是cnt∗(cnt−1)cnt*(cnt-1)cnt(cnt1)[也就是这cnt个数组两两配对的个数],那么此时我们的这个数字的总贡献就是m∗(m+1)/2−cnt∗(cnt−1)m*(m+1)/2-cnt*(cnt-1)m(m+1)/2cnt(cnt1)

所以我们此时的问题就变成了如何计算出这么多的数组里面每一个数字的个数.每一次更改时,我们可以使用lastlastlast数组来记录上一次该数字出现的位置,然后计算一下这个数字知道消失所存在的数组此处即可.并且需要注意的我们还需要累计每一个数字一直到最后的存在的次数

下面是具体的代码部分:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define root 1,n,1
#define ls rt<<1
#define rs rt<<1|1
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
inline ll read() {ll x=0,w=1;char ch=getchar();for(;ch>'9'||ch<'0';ch=getchar()) if(ch=='-') w=-1;for(;ch>='0'&&ch<='9';ch=getchar()) x=x*10+ch-'0';return x*w;
}
#define int long long
#define maxn 1000000
const double eps=1e-8;
#define	int_INF 0x3f3f3f3f
#define ll_INF 0x3f3f3f3f3f3f3f3f
int T;int n;int m;int last[maxn];
int a[maxn];int cnt[maxn];
void init() {for(int i=1;i<=n+m;i++) {last[i]=-1;cnt[i]=0;}
}
signed main() {T=read();while(T--) {n=read();m=read();init();for(int i=1;i<=n;i++){a[i]=read();last[a[i]]=0;} for(int i=1;i<=m;i++) {int pos=read(),val=read();cnt[a[pos]]+=i-last[a[pos]];last[a[pos]]=-1;last[val]=i;a[pos]=val;}for(int i=1;i<=n+m;i++) {if(last[i]!=-1) {cnt[i]+=(m+1-last[i]);}}ll ans=2*n*(m+1)*(m)/2;for(int i=1;i<=n+m;i++) {ans-=cnt[i]*(cnt[i]-1)/2;}printf("%lld\n",ans);}return 0;
}
http://www.yayakq.cn/news/470945/

相关文章:

  • 平远县建设工程交易中心网站数字化营销系统
  • 网站建设需要些什么东西西安城乡住房建设厅网站首页
  • 商洛网站开发智慧团建密码一般是什么
  • 芜湖网站建设价格值得浏览的国外网站
  • 桂林做网站的公司哪家最好燃灯seo
  • 自己可以做微网站吗网页界面设计是什么
  • 做网站用jsp还是html网站强制qq弹窗代码
  • 湖南营销网站建设设计ps为什么做不了视频网站
  • 北京网站建设最便宜的公司哪家好国内重大新闻
  • 大连网站建设详细流程品牌vi设计升级
  • 襄阳哪里做网站北京信息
  • 专业做国际网站自适应网站开发教程
  • 头条新闻 免费下载旺道seo工具
  • 建筑网站起名网站未备案做seo会被k吗
  • 银行的网站怎么做国外哪些网站有黄图
  • 谭谭心怎么建设网站发布新闻稿
  • 蚌埠做网站公司app制作教程视频全集
  • 济南哪个网站建设最好黄冈网站建设收费
  • 神鹰网站建设公司网络销售的技巧和话术
  • 网站中二级导航栏怎么做网站建商城
  • 中小学图书馆网站建设wordpress 金融主题
  • 国外获奖flash网站linux国外网站吗
  • 目前做网站框架网站后期维护价格
  • 国外网站建设发展现状苏州小程序开发外包
  • 关于asp网站模板下载提供手机网站开发
  • 电脑记事本做网站医疗网站建设案例
  • 手机wap网站建设多少钱外贸网站特点
  • 代理注册公司网站模版利用网上菜谱做网站
  • 山东省建设项目备案证明网站wordpress 更改目录
  • 网站建设定制价格明细表产品包装设计创意