【剑指offer】数组中的逆序对
版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/mmc_maodun/article/details/27520535
转载请注明出处:http://blog.csdn.net/ns_code/article/details/27520535
- 题目描写叙述:
- 在数组中的两个数字。假设前面一个数字大于后面的数字,则这两个数字组成一个逆序对。
输入一个数组。求出这个数组中的逆序对的总数。
- 输入:
-
每一个測试案例包括两行:第一行包括一个整数n,表示数组中的元素个数。
当中1 <= n <= 10^5。
第二行包括n个整数,每一个数组均为int类型。
- 输出:
- 相应每一个測试案例。输出一个整数,表示数组中的逆序对的总数。
- 例子输入:
-
4
7 5 6 4
- 例子输出:
-
5
剑指offer给出了归并排序的思路。这个有点难想到啊,也可能是我太弱了,根本没往这方面想!理解了思路。就不难了,将数组划分成两个子数组。再将子数组分别划分成两个子数组。统计每一个子数组内的逆序对个数,并将其归并排序。再统计两个子数组之间的逆序对个数,并进行归并排序。
这就是归并排序的变种,在归并排序代码的基础上稍作改进就可以。
#include<stdio.h>
#include<stdlib.h>
/*
统计两个子数组之间的逆序对
*/
long long MergePairsBetweenArray(int *arr,int *brr,int start,int mid,int end)
{
int i = mid;
int j = end;
int k = end; //辅助数组的最后一位
long long count = 0;
//设置两个指针i,j分别从右往左依次比較。
//将较大的依次放入辅助数组的右边
while(i>=start && j>=mid+1)
{
if(arr[i] > arr[j])
{
count += j-mid;
brr[k--] = arr[i--];
}
else
brr[k--] = arr[j--];
}
//将当中一个数组中还剩下的元素复制到辅助数组中。
//两个循环仅仅会运行当中的一个
while(i>=start)
brr[k--] = arr[i--];
while(j>=mid+1)
brr[k--] = arr[j--];
//从辅助数组中将元素复制到原数组中。使其有序排列
for(i=end;i>k;i--)
arr[i] = brr[i];
return count;
}
/*
统计数组中的全部的逆序对
*/
long long CountMergePairs(int *arr,int *brr,int start,int end)
{
long long PairsNum = 0;
if(start<end)
{
int mid = (start+end)>>1;
PairsNum += CountMergePairs(arr,brr,start,mid); //统计左边子数组的逆序对
PairsNum += CountMergePairs(arr,brr,mid+1,end); //统计右边子数组的逆序对
PairsNum += MergePairsBetweenArray(arr,brr,start,mid,end); //统计左右子数组间的逆序对
}
return PairsNum;
}
/*
将函数封装起来
*/
long long CountTotalPairs(int *arr,int len)
{
if(arr==NULL || len<2)
return 0;
int *brr = (int *)malloc(len*sizeof(int));
if(brr == NULL)
exit(EXIT_FAILURE);
long long sum = CountMergePairs(arr,brr,0,len-1);
free(brr);
brr = NULL;
return sum;
}
int main()
{
int n;
while(scanf("%d",&n) != EOF)
{
int *arr = (int *)malloc(n*sizeof(int));
if(arr == NULL)
exit(EXIT_FAILURE);
int i;
for(i=0;i<n;i++)
scanf("%d",arr+i);
printf("%lld\n",CountTotalPairs(arr,n));
free(arr);
arr = NULL;
}
return 0;
}
/************************************************************** Problem: 1348 User: mmc_maodun Language: C Result: Accepted Time:100 ms Memory:1696 kb****************************************************************/【剑指offer】数组中的逆序对的更多相关文章
- [剑指OFFER] 数组中的逆序对
题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数. 分析:利用归并排序的思想,分成2部分,每一部分按照从大到 ...
- 剑指Offer——数组中的逆序对
题目描述: 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%100 ...
- 用js刷剑指offer(数组中的逆序对)
题目描述 题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P ...
- 剑指Offer——数组中的逆序对(归并排序的应用)
蛮力: 遍历数组,对每个元素都往前遍历所有元素,如果有发现比它小的元素,就count++. 最后返回count取模. 结果没问题,但超时哈哈哈,只能过50%. 归并法: 看讨论,知道了这道题的经典 ...
- 剑指 Offer——数组中的逆序对
1. 题目 2. 解答 借助于归并排序的分治思想,在每次合并的时候统计逆序对.因为要合并的两个数组都是有序的,如果左半部分数组当前值大于右半部分数组当前值,那么左半部分数组当前值右边的数就都大于右半部 ...
- 剑指offer_数组中的逆序对
题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P. 并将P对1000000007取模的结果输出. 即输出P%100 ...
- 剑指Offer-34.数组中的逆序对(C++/Java)
题目: 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%10000 ...
- 剑指Offer34 数组中的逆序对
/************************************************************************* > File Name: 34_Invers ...
- 剑指offer-数组中的逆序对-数组-python
题目描述 在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对.输入一个数组,求出这个数组中的逆序对的总数P.并将P对1000000007取模的结果输出. 即输出P%1000 ...
- 剑指 Offer —— 数组中重复的数字
数组中的重复数字 题目描述 牛课网链接 长度为 n 的数组里,所有数字都在 0 到 n-1 的范围内. 数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任意一 ...
随机推荐
- 用jQuery来绑定事件的3种方法和区别
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Java - 网络IO的阻塞
最近学习时碰到事件驱动和非阻塞的相关知识,随之想到了Java中的Reactor.io与nio的一些东西:在前辈的博客上翻了翻.复习复习,在此记录一番. 实在找不到比较大点的东西,于是随便弄了个压缩包, ...
- Java实现在线预览–openOffice实现
实现逻辑有两种: 一.利用jodconverter(基于OpenOffice服务)将文件(.doc..docx..xls..ppt)转化为html格式. 二.利用jodconverter(基于Open ...
- Java面试题之HashMap阿里面试必问知识点,你会吗?
面试官Q1:你用过HashMap,你能跟我说说它的数据结构吗? HashMap作为一种容器类型,无论你是否了解过其内部的实现原理,它的大名已经频频出现在各种互联网Java面试题中了.从基本的使用角度来 ...
- PHP支持多线程吗?
https://zhidao.baidu.com/question/2053529640037778107.html
- 三种角度解释href/src/link/import区别
网上查到的几种不同但比较容易理解的解释 解释一: href是Hypertext Reference的缩写,表示超文本引用.用来建立当前元素和文档之间的链接.常用的有:link.a.例如: <li ...
- centos install redis
1. 下载 [logan@localhost java]$ wget http://download.redis.io/releases/redis-3.2.8.tar.gz2. 解压 [log ...
- Strapi 安装易错位置
Strapi官网(https://strapi.io)介绍:最先进的开源内容管理框架,可以毫不费力地构建功能强大的API,建立在Node.js平台之上,为您的API提供高速惊人的表现. 简单点说,(对 ...
- .NET开源工作流RoadFlow-流程运行-工作委托
如果某一个人某一段时间不在单位,则可以将自己的工作委托给他人代为处理. 在 流程处理-->工作委托 中可以管理自己的委托,管理员也可以在 流程管理-->工作委托 中管理所有人的委托: 委托 ...
- 树莓派搭建web服务器(详细且良心)
安装Apache Apache服务器可以从Debian的源中下载.可以用apt下载. 首先要更新apt的软件列表.如果不运行sudo apt-get updata的话,apt软件就不知道有没有新的软件 ...