码迷,mamicode.com
首页 > 其他好文 > 详细

代码模板(new)

时间:2020-04-18 20:11:25      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:pac   close   using   out   二进制   ons   pair   space   代码   

1.树状数组:题目:UVA1428

技术图片
 1 #include<iostream>
 2 #include<algorithm>
 3 #include<cstdio>
 4 #include<string>
 5 #include<cstring>
 6 #include<numeric>
 7 #include<vector>
 8 #include<map>
 9 #include<queue>
10 #include<set>
11 #include<cmath>
12 using namespace std;
13 typedef long long ll;
14 typedef pair<int,int>PII;
15 typedef pair<ll,ll>PLL;
16 
17 //树状数组和线段树是一样的下标均是从1开始的。。。这个一定不能出错。。。
18 
19 const int maxn=1e5+10;
20 
21 int tree[maxn+10];//树状数组。。。
22 int l[maxn+10],r[maxn+10];
23 
24 int lowbit(int x){//求解一个数二进制最后一个1的位置。。。
25     return x&(-x);
26 }
27 //树状数组求和不同于线段树每一次直接拿出来,树状数组的求和有可能每一次要进行加减的操作。。。
28 
29 int sum(int x){//注意x均是tree树状数组的下标。。。
30     int res=0;
31     while(x>0){//通过lowbit找只有最后一个1的数的值,我们只需要确定二进制存在1那么就继续遍历操作。。。
32         res+=tree[x];
33         x-=lowbit(x);//eg:x=7那么之后加上6,之后加上4,之后x为0,跳出循环。。。结束操作。。。
34     }
35     return res;//直接求出和。。
36 }
37 
38 void add(int x,int d){//这一步是增加操作。。。是从树根往上面进行操作。。。
39     while(x<maxn){
40         tree[x]+=d;//将当前的结点加上去。。。是从下往上加的。。。
41         x+=lowbit(x);//x是树的下标。。。
42     }
43 }
44 
45 //l[i],r[i]记录的都是比i位置数字要小的数字的个数。。。
46 
47 int main(){
48     int T;
49     cin>>T;
50     ll ans;
51     while(T--){
52         int a[maxn];
53         int n;
54         cin>>n;
55         for(int i=1;i<=n;i++){
56             cin>>a[i];
57         }
58         memset(tree,0,sizeof(tree));
59         memset(l,0,sizeof(l));
60         for(int i=1;i<=n;i++){
61             l[i]=sum(a[i]);
62             add(a[i],1);//个数均加一
63         }
64         memset(tree,0,sizeof(tree));
65         memset(r,0,sizeof(r));
66         for(int i=n;i>=1;i--){
67             r[i]=sum(a[i]);
68             add(a[i],1);
69         }
70         ans=0;
71         for(int i=2;i<n;i++){
72             ans=ans+l[i]*(n-r[i]-i)+r[i]*(i-1-l[i]);
73         }
74         cout<<ans<<endl;
75     }
76 
77     return 0;
78 }
View Code

 

代码模板(new)

标签:pac   close   using   out   二进制   ons   pair   space   代码   

原文地址:https://www.cnblogs.com/zb121/p/12727719.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!