#include<stdio.h>
long long int s;
void ms(int a[],int p,int r)
{
int q;
if(p<r)
{
q=(p+r)/2;
ms(a,p,q);
ms(a,q+1,r);
merge(a,p,q,r);
}
}
void merge(int a[],int p,int q,int r)
{
int n1,n2;
int i,j,k;
int L[1000],R[1000];
n1=q-p+1;
n2=r-q;
for(i=1;i<=n1;i++)
L[i]=a[p+i-1];
for(j=1;j<=n2;j++)
R[j]=a[q+j];
i=1;
j=1;
L[n1+1]=12542568;
R[n2+1]=3655423654;
for(k=p;k<=r;k++)
{
if(L[i]<=R[j])
{
a[k]=L[i];
i++;
}
else
{
a[k]=R[j];
s+=n1+1-i;
j++;
}
}
}
int main()
{
int n;
int i,a[100];
while(scanf("%d",&n)!=EOF)
{
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
i=1;
s=0;
ms(a,i,n);
printf("%d\n",s);
}
return 0;
}
long long int s;
void ms(int a[],int p,int r)
{
int q;
if(p<r)
{
q=(p+r)/2;
ms(a,p,q);
ms(a,q+1,r);
merge(a,p,q,r);
}
}
void merge(int a[],int p,int q,int r)
{
int n1,n2;
int i,j,k;
int L[1000],R[1000];
n1=q-p+1;
n2=r-q;
for(i=1;i<=n1;i++)
L[i]=a[p+i-1];
for(j=1;j<=n2;j++)
R[j]=a[q+j];
i=1;
j=1;
L[n1+1]=12542568;
R[n2+1]=3655423654;
for(k=p;k<=r;k++)
{
if(L[i]<=R[j])
{
a[k]=L[i];
i++;
}
else
{
a[k]=R[j];
s+=n1+1-i;
j++;
}
}
}
int main()
{
int n;
int i,a[100];
while(scanf("%d",&n)!=EOF)
{
for(i=1;i<=n;i++)
scanf("%d",&a[i]);
i=1;
s=0;
ms(a,i,n);
printf("%d\n",s);
}
return 0;
}
No comments:
Post a Comment