问题描述

给定一个 1~N 的排列 P,即 1 到 N 中的每个数在 P 都只出现一次。 现在要
对排列 P 进行冒泡排序,代码如下:
for (int i = 1; i <= N; ++i)
for (int j = N, t; j > i; ‐‐j)
if (P[j ‐ 1] > P[j])
t = P[j], P[j] = P[j ‐ 1], P[j ‐ 1] = t;
在排序过程中,数字的位置可能会发生变化。对于 1~ N 的每个数字,你需
要输出过程中达到的最左位置下标和最右位置下标的差的绝对值。

★数据输入
第一行为 N,表示排列长度。
第二行为排列 P。
数据保证:
80%的数据, N <= 1000
100%的数据, N <= 100000

★数据输出
输出一行,第 i 个数字表示数字 i 最左与最右位置的差的绝对值。

输入示例 输出示例
4
3 2 1 4
2 1 2 0

★注释
样例冒泡排序过程:
swap 2 1: 3 2 1 4 > 3 1 2 4
swap 3 1: 3 1 2 4 > 1 3 2 4
swap 3 2: 1 3 2 4 > 1 2 3 4

思路

  定义结构体,成员有:data(数据值、排序后下标)、pos(排序前下标)、num(当前数右边比它小的数)

  归并,过程中统计数右边比它小的数,更新num

  最大下标为pos+num,最小下标为data或pos

  PS:好像用树状数组做也可以,但是我不会╮(๑•́ ₃•̀๑)╭

code

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. struct Node
  5. {
  6. int data;
  7. int pos;
  8. int num;
  9. };
  10.  
  11. Node *buf;
  12.  
  13. inline int max(int a, int b)
  14. {
  15. return a>b?a:b;
  16. }
  17. inline int min(int a,int b)
  18. {
  19. return a<b?a:b;
  20. }
  21.  
  22. void mergesort(Node *arr, int l,int r)
  23. {
  24. if(l>=r) return ;
  25. if(l+==r)
  26. {
  27. if(arr[l].data > arr[r].data)
  28. {
  29. Node tmp = arr[l];
  30. arr[l] = arr[r];
  31. arr[r] = tmp;
  32. arr[r].num++;
  33. }
  34. }
  35.  
  36. int m = (l+r)/;
  37. int i,j,k;
  38. int num=;
  39. mergesort(arr,l,m);
  40. mergesort(arr,m+,r);
  41. for(i=l;i<=r;i++) buf[i] = arr[i];
  42. for(k=l,i=l,j=m+ ; k<=r; k++)
  43. {
  44. if(i>m)
  45. {
  46. arr[k] = buf[j++];
  47. }
  48. else if(j>r)
  49. {
  50. arr[k] = buf[i++];
  51. arr[k].num += num;
  52. }
  53. else if(buf[i].data < buf[j].data)
  54. {
  55. arr[k] = buf[i++];
  56. arr[k].num += num;
  57. }
  58. else
  59. {
  60. arr[k] = buf[j++];
  61. num++;
  62. }
  63. }
  64. }
  65.  
  66. int main()
  67. {
  68. int i,j,k;
  69. int n;
  70. scanf("%d",&n);
  71. Node *arr = (Node *)malloc(sizeof(Node)*(n+));
  72. buf = (Node *)malloc(sizeof(Node)*(n+));
  73. for(i=;i<=n;i++)
  74. {
  75. scanf("%d",&arr[i].data);
  76. arr[i].pos = i;
  77. arr[i].num = ;
  78. }
  79. mergesort(arr,,n);
  80. for(i=;i<=n;i++)
  81. {
  82. if(i==)
  83. printf("%d",arr[i].num+arr[i].pos-min(arr[i].data,arr[i].pos));
  84. else
  85. printf(" %d",arr[i].num+arr[i].pos-min(arr[i].data,arr[i].pos));
  86. }
  87. printf("\n");
  88.  
  89. free(arr);
  90. free(buf);
  91. return ;
  92. }

数据结构_bubble_sort的更多相关文章

  1. 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)

    前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...

  2. 一起学 Java(三) 集合框架、数据结构、泛型

    一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...

  3. 深入浅出Redis-redis底层数据结构(上)

    1.概述 相信使用过Redis 的各位同学都很清楚,Redis 是一个基于键值对(key-value)的分布式存储系统,与Memcached类似,却优于Memcached的一个高性能的key-valu ...

  4. 算法与数据结构(十五) 归并排序(Swift 3.0版)

    上篇博客我们主要聊了堆排序的相关内容,本篇博客,我们就来聊一下归并排序的相关内容.归并排序主要用了分治法的思想,在归并排序中,将我们需要排序的数组进行拆分,将其拆分的足够小.当拆分的数组中只有一个元素 ...

  5. 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)

    本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ...

  6. 算法与数据结构(九) 查找表的顺序查找、折半查找、插值查找以及Fibonacci查找

    今天这篇博客就聊聊几种常见的查找算法,当然本篇博客只是涉及了部分查找算法,接下来的几篇博客中都将会介绍关于查找的相关内容.本篇博客主要介绍查找表的顺序查找.折半查找.插值查找以及Fibonacci查找 ...

  7. 算法与数据结构(八) AOV网的关键路径

    上篇博客我们介绍了AOV网的拓扑序列,请参考<数据结构(七) AOV网的拓扑排序(Swift面向对象版)>.拓扑序列中包括项目的每个结点,沿着拓扑序列将项目进行下去是肯定可以将项目完成的, ...

  8. 算法与数据结构(七) AOV网的拓扑排序

    今天博客的内容依然与图有关,今天博客的主题是关于拓扑排序的.拓扑排序是基于AOV网的,关于AOV网的概念,我想引用下方这句话来介绍: AOV网:在现代化管理中,人们常用有向图来描述和分析一项工程的计划 ...

  9. 掌握javascript中的最基础数据结构-----数组

    这是一篇<数据结构与算法javascript描述>的读书笔记.主要梳理了关于数组的知识.部分内容及源码来自原作. 书中第一章介绍了如何配置javascript运行环境:javascript ...

随机推荐

  1. THUWC2017

    100+20+20=140 还是很菜... T1 在美妙的数学王国中畅游 一棵树每个点有一个函数(sin,exp,一次函数),支持加边,删边,单点修改,查询一条路径在 $x$ 处的点值和 sol: 题 ...

  2. HttpServletRequest获取请求得URL信息

    request对象中包含的是请求信息,当我们在浏览器地址栏上输入:http://localhost:8080/Example/AServlet?username=zhangsan,这段地址也会作为请求 ...

  3. Yii的常用URL和渲染方法

    当前页面url  Yii::app()->request->url;跳转前一个页面url $this->redirect(Yii::app()->request->url ...

  4. 页面报错Uncaught SyntaxError: Unexpected identifier

    错误描述:未捕获的语法错误:意想不到的标识符. 如图所示:检查之后发现是页面js内缺少“,”引起的.添加之后就OK了.

  5. C#:使用UPnP来穿透NAT使内网接口对外网可见

    在写完Object 672后,软件的一个致命问题暴露出来,如果服务器和客户端都在内网环境下,即双方都通过NAT来接触外网,那么此时客户端是无法直接和服务器交流的. 解决方案可以是: 1:把服务器部署在 ...

  6. bzoj 3028 食物——生成函数

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3028 把式子写出来,化一化,变成 x / ((1-x)^4) ,变成几个 sigma 相乘的 ...

  7. C# 常用文件操作

    public class IoHelper { /// <summary> /// 判断文件是否存在 /// </summary> /// <param name=&qu ...

  8. linux下redis服务器安装使用 安装php的redis扩展 安装laravel下的redis

    linux下redis服务器安装使用 学习源头: https://blog.csdn.net/itmanba/article/details/77335012 安装完毕试运行redis的时候,可能会出 ...

  9. 反射ORM

    七章    反射 1节获取dll文件中的type---------------------------------------------------------------------------- ...

  10. FPGA的年龄

    FPGA的年龄 1984年,Xilinx公司发布了第一个FPGA(但直到1985年这些器件才真正发货).尽管这些器件比当时那些简单的可编程逻辑器件(PLD)复杂的多,但大多数数字设计工程师却仅仅用这些 ...