不用ABAP的标准SORT语句,你能将下面这个数组按从小到大(或从大到小)的顺序重新排列,并计算其算法复杂度吗?

现在假设有一个数组:A = [10,66,52,102,-65,85,99,1,56,32,10,21,18]

算法思想一:

按数组顺序,每次读取一个数字放到新数组中,将这个数字与该数组中所有数字进行循环比较,确定存放位置

原数组:A = [10,66,52,102,-65,85,99,1,56,32,10,21,18]

步骤  

 排序后数组

1

10

2

10 66

3

10 52 66

4

10 52   66  102

5

-65 10 52 66 102

6

-65 10 52 66 85   102

7

。。。

8

。。。。。。

算法思想二:

每次从数组A重拿出一个最大(或最小)数字,拿出之后将数组A中的数字删除该数字,然后循环直到数组A被删空。

原数组:A = [10,66,52,102,-65,85,99,1,56,32,10,21,18]

 步骤

  新数组

          数组A中剩余

1

-65

10,66,52,102,85,99,1,56,32,10,21,18

2

-65

10,66,52,102,85,99,56,32,10,21,18

3

-65 1 10 10

66,52,102,85,99,56,32,21,18

4

-65 1   10 10

66,52,102,85,99,56,32,21

5

-65 1   10 10 18

66,52,102,85,99,56,32

6

。。。

。。。。。。

7

。。。。。。

。。。

个人写的ABAP代码如下(采用的第二种算法思想,希望各位博友能看明白):

1.首先随机制造10个[-100,100]内的随机不重复的数字放到数组A中,

2.然后循环数组A,并每次取出一个最大的数字放到数组B中,然后删除数组A中的该数字,直到数组A被清空。

代码如下:

 *&---------------------------------------------------------------------*
*& Report ZCHENH038
*&
*&---------------------------------------------------------------------*
*&
*&不用标准 sort语法 自己写排序语法
*&---------------------------------------------------------------------* REPORT zchenh038. DATA:BEGIN OF a OCCURS ,
num TYPE i,
END OF a,
b LIKE STANDARD TABLE OF a. PERFORM frm_full_data .
PERFORM frm_show_data USING '排序前'. PERFORM frm_sort.
PERFORM frm_show_data USING '排序后'. *&---------------------------------------------------------------------*
*& Form FRM_FULL_DATA
*&---------------------------------------------------------------------*
* 随机产生10个 -100 到100 之间不重复的数
*----------------------------------------------------------------------*
* --> p1 text
* <-- p2 a
*----------------------------------------------------------------------*
FORM frm_full_data.
DATA:lv_len TYPE i.
WHILE lv_len < .
* 随机产生一个数
CALL FUNCTION 'QF05_RANDOM_INTEGER'
EXPORTING
ran_int_max =
ran_int_min = -
IMPORTING
ran_int = a-num.
READ TABLE a WITH KEY num = a-num.
CHECK sy-subrc <> .
APPEND a.
DESCRIBE TABLE a LINES lv_len.
ENDWHILE. ENDFORM. " FRM_FULL_DATA
*&---------------------------------------------------------------------*
*& Form FRM_SORT
*&---------------------------------------------------------------------*
* 开始排序
*----------------------------------------------------------------------*
* --> p1 text
* <-- p2 a
*----------------------------------------------------------------------*
FORM frm_sort .
DATA:lt_b LIKE a OCCURS WITH HEADER LINE.
WHILE a[] IS NOT INITIAL.
PERFORM frm_get_min TABLES a
CHANGING lt_b-num.
APPEND lt_b.
DELETE a WHERE num = lt_b-num.
ENDWHILE.
a[] = lt_b[].
ENDFORM. " FRM_SORT *&---------------------------------------------------------------------*
*& Form frm_min
*&---------------------------------------------------------------------*
* 找出t_a 中最小的数 p_n
*----------------------------------------------------------------------*
* --> p1 t_a
* <-- p2 p_n
*----------------------------------------------------------------------*
FORM frm_get_min TABLES t_a LIKE b
CHANGING p_n.
READ TABLE t_a INDEX .
p_n = t_a-num.
LOOP AT t_a.
IF t_a-num <= p_n.
p_n = t_a-num.
ENDIF.
ENDLOOP.
ENDFORM. "frm_min
*&---------------------------------------------------------------------*
*& Form FRM_SHOW_DATA
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* --> p1 text
* <-- p2 text
*----------------------------------------------------------------------*
FORM frm_show_data USING p_str TYPE string.
WRITE:/,p_str,':'.
LOOP AT a.
WRITE:a-num,' '.
ENDLOOP.
ENDFORM. " FRM_SHOW_DATA

运行效果如图:

ABAP 自定义排序的思想(不用系统标准的SORT语句)的更多相关文章

  1. python学习之算法、自定义模块、系统标准模块(上)

    算法.自定义模块.系统标准模块(time .datetime .random .OS .sys .hashlib .json和pickle) 一:算法回顾: 冒泡算法,也叫冒泡排序,其特点如下: 1. ...

  2. Python 第五篇(下):系统标准模块(shutil、logging、shelve、configparser、subprocess、xml、yaml、自定义模块)

    目录: shutil logging模块 shelve configparser subprocess xml处理 yaml处理 自定义模块 一,系统标准模块: 1.shutil:是一种高层次的文件操 ...

  3. Python 第五篇(上):算法、自定义模块、系统标准模块(time 、datetime 、random 、OS 、sys 、hashlib 、json和pickle)

    一:算法回顾: 冒泡算法,也叫冒泡排序,其特点如下: 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个. 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应 ...

  4. 【C++】标准库sort函数的自定义排序

    自定义排序需要单独写一个compare函数 例1 LeetCode 056. Merge Intervals Given a collection of intervals, merge all ov ...

  5. .NET/C#中对自定义对象集合进行自定义排序的方法

    一个集合可否排序,要看系统知不知道排序的规则,像内建的系统类型,int ,string,short,decimal这些,系统知道怎么排序,而如果一个集合里面放置的是自定义类型,比如自己定义了一个Car ...

  6. Python自定义排序及我实际遇到的一些题目实例

    写在前面,本文主要介绍Python基础排序和自定义排序的一些规则,如果都比较熟悉,可以直接翻到第三节,看下实际的笔试面试题中关于自定义排序的应用. 一.基础排序 排序是比较基础的算法,与很多语言一样, ...

  7. Objective-C之NSArray(数组)默认排序与自定义排序

    在讲OC中数组的排序之前我先上一段代码,它是简单数组排序的一种方法(也就是元素是字符串或者数据的数组,因为后面要讲元素为类的数组排序) 代码1: NSArray *sortArr4 = [sortAr ...

  8. XtraReport交叉表隐藏列标题及自定义排序

    1.隐藏列标题 用DevExpress PivotGrid report 做报表的时候,将字段拖放到报表中后,ColumnArea和DataArea会显示两个标题字段,如下图: 选中交叉表,设置以下属 ...

  9. Easyui datagrid自定义排序

    做项目遇到个关于排序问题,想着在前端排序,正好Easyui有这个功能,所以就拿来用了一下,因为跟官网的Demo不太一样,所以总结一下: 首先这一列是要排序的列(当然,在生产环境,这一列是隐藏的,在开发 ...

随机推荐

  1. api文档管理系统合集

    1.Swagger 2.Showdoc 3.EOAPI 4.阿里的RAP 5.postMan 6.docute: 无需编译的文档撰写工具 7.SmartWiki 接口文档在线管理系统 8.SosoAp ...

  2. ROS学习手记 - 5 理解ROS中的基本概念_Services and Parameters

    上一节完成了对nodes, Topic的理解,再深入一步: Services and Parameters 我不理解为何 ROS wiki 要把service与parameter放在一起介绍, 很想分 ...

  3. The difference between Spring Tool Suite and Spring IDE

    The difference between Spring Tool Suite and Spring IDE Spring Tool Suite和Spring IDE的区别: http://down ...

  4. uva-519-拼图

    给你N*M个碎片,问能否用他们拼成一个矩形,矩形的边缘要全是F,除外界边缘的边要么是I,要么O,不能是F1.碎片会重复出现,所以同样的碎片在同一个位置,如果已经不能放,直接跳过就行2.矩形的边缘要全是 ...

  5. 432 4.3.2 STOREDRV.Deliver; recipient thread limit exceeded

    最近几天Hub-Mailbox服务器时不时就CPU超过90%.在任务管理器里面看到edgetransport占用大量CPU.进入EMC的队列查看器,看到邮箱数据库堵塞,队列上万. 堵塞的邮件大多是收件 ...

  6. FreeMarker生成Word文档

    FreeMarker简介: FreeMarker是一款模板引擎:即一种基于模板和要改变的数据,并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具,它不是面向最终用户的,而是一个 ...

  7. ADO.net 增删改查

    ADO.net 一.定义:编程开发语言与数据库连接的一门语言技术 二.链接: 在vs中操作数据库需在开头进行链接 链接内容:using System.Data.SqlClient 三.引用数据库: 四 ...

  8. Linux上VNC常见命令

    参考链接: http://blog.csdn.net/russle/article/details/4757888 http://www.linuxidc.com/Linux/2016-06/1320 ...

  9. js 只允许输入数字

    <input id="credit" type="text" class="nummber" onkeyup="value= ...

  10. LeetCode题解 Permutations II 和 Permutations I ——回溯算法

    这个算法感觉还是很陌生的.算法导论里没有讲这个算法,而数据结构与算法分析只用了一节来阐述.我居然跳过去了..尴尬. 笨方法解决的: 第一题: 给定一个元素不重复的数组,枚举出他们的全排列. 方法1:递 ...