离散化+树状数组逆序对

本文介绍了两种基于C++的算法实现:一种是利用映射和排序进行元素重排的方法;另一种则是通过线段树和低级位操作计算逆序对数量的技巧。通过具体的代码示例展示了如何有效地处理这类问题。

这篇只是简单的排序啦

#include<bits/stdc++.h>
using namespace std;
int n,a[10050],ans[10050],tp[10050];
map<int,int> mp;
int main(){
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i],tp[i]=a[i];
    sort(tp+1,tp+1+n);
    int m=unique(tp+1,tp+1+n)-(tp+1);
    for(int i=1;i<=m;i++)
        mp[tp[i]]=i; 
    for(int i=1;i<=n;i++)
        ans[i]=mp[a[i]];
    for(int i=1;i<=n;i++) printf("%d ",ans[i]);return 0;
}

 逆序对,在线插入后1,查比自己大的数和即可

#include<bits/stdc++.h>
#define rep(i,x,y) for(register int i=x;i<=y;i++)
using namespace std;
int n,a[10050],ans,c[10050],mx;
inline int lowbit(int x){return x&(-x);}
void change(int x){for(;x<=mx;x+=lowbit(x)) c[x]++;return;}
int sum(int x){int ans=0;for(;x;x-=lowbit(x)) ans+=c[x];return ans;}
int main(){
    freopen("5.in","r",stdin);
    cin>>n;mx=-1;
    rep(i,1,n) cin>>a[i],mx=max(mx,a[i]);
    rep(i,1,n) change(a[i]),ans+=i-sum(a[i]);
    printf("%d",ans);return 0;
}

 

转载于:https://www.cnblogs.com/asdic/p/9614838.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值