本篇内容介绍了“如何实现逆序对的数量归并”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int N=100010; typedef long long LL; int n; int q[N],t[N]; LL res=0; void merge_sort(int q[],int l,int r){ if(l>=r) return; int m=(l+r)>>1; merge_sort(q,l,m); merge_sort(q,m+1,r); //开始归并 int i=l,j=m+1; int k=0; while(i<=m && j<=r){ if(q[i]<=q[j]) t[k++]=q[i++]; else{ t[k++]=q[j++]; res=res+m-i+1; } } //扫尾 while(i<=m) t[k++]=q[i++]; while(j<=r) t[k++]=q[j++]; //搞回去 for(int i=l,j=0;i<=r;i++,j++) q[i]=t[j]; } int main(){ cin>>n; for(int i=0;i<n;i++) cin>>q[i]; merge_sort(q,0,n-1); cout<<res<<endl; return 0; }
“如何实现逆序对的数量归并”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。