ABAP 自定义排序的思想(不用系统标准的SORT语句)
不用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语句)的更多相关文章
- python学习之算法、自定义模块、系统标准模块(上)
算法.自定义模块.系统标准模块(time .datetime .random .OS .sys .hashlib .json和pickle) 一:算法回顾: 冒泡算法,也叫冒泡排序,其特点如下: 1. ...
- Python 第五篇(下):系统标准模块(shutil、logging、shelve、configparser、subprocess、xml、yaml、自定义模块)
目录: shutil logging模块 shelve configparser subprocess xml处理 yaml处理 自定义模块 一,系统标准模块: 1.shutil:是一种高层次的文件操 ...
- Python 第五篇(上):算法、自定义模块、系统标准模块(time 、datetime 、random 、OS 、sys 、hashlib 、json和pickle)
一:算法回顾: 冒泡算法,也叫冒泡排序,其特点如下: 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个. 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应 ...
- 【C++】标准库sort函数的自定义排序
自定义排序需要单独写一个compare函数 例1 LeetCode 056. Merge Intervals Given a collection of intervals, merge all ov ...
- .NET/C#中对自定义对象集合进行自定义排序的方法
一个集合可否排序,要看系统知不知道排序的规则,像内建的系统类型,int ,string,short,decimal这些,系统知道怎么排序,而如果一个集合里面放置的是自定义类型,比如自己定义了一个Car ...
- Python自定义排序及我实际遇到的一些题目实例
写在前面,本文主要介绍Python基础排序和自定义排序的一些规则,如果都比较熟悉,可以直接翻到第三节,看下实际的笔试面试题中关于自定义排序的应用. 一.基础排序 排序是比较基础的算法,与很多语言一样, ...
- Objective-C之NSArray(数组)默认排序与自定义排序
在讲OC中数组的排序之前我先上一段代码,它是简单数组排序的一种方法(也就是元素是字符串或者数据的数组,因为后面要讲元素为类的数组排序) 代码1: NSArray *sortArr4 = [sortAr ...
- XtraReport交叉表隐藏列标题及自定义排序
1.隐藏列标题 用DevExpress PivotGrid report 做报表的时候,将字段拖放到报表中后,ColumnArea和DataArea会显示两个标题字段,如下图: 选中交叉表,设置以下属 ...
- Easyui datagrid自定义排序
做项目遇到个关于排序问题,想着在前端排序,正好Easyui有这个功能,所以就拿来用了一下,因为跟官网的Demo不太一样,所以总结一下: 首先这一列是要排序的列(当然,在生产环境,这一列是隐藏的,在开发 ...
随机推荐
- api文档管理系统合集
1.Swagger 2.Showdoc 3.EOAPI 4.阿里的RAP 5.postMan 6.docute: 无需编译的文档撰写工具 7.SmartWiki 接口文档在线管理系统 8.SosoAp ...
- ROS学习手记 - 5 理解ROS中的基本概念_Services and Parameters
上一节完成了对nodes, Topic的理解,再深入一步: Services and Parameters 我不理解为何 ROS wiki 要把service与parameter放在一起介绍, 很想分 ...
- 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 ...
- uva-519-拼图
给你N*M个碎片,问能否用他们拼成一个矩形,矩形的边缘要全是F,除外界边缘的边要么是I,要么O,不能是F1.碎片会重复出现,所以同样的碎片在同一个位置,如果已经不能放,直接跳过就行2.矩形的边缘要全是 ...
- 432 4.3.2 STOREDRV.Deliver; recipient thread limit exceeded
最近几天Hub-Mailbox服务器时不时就CPU超过90%.在任务管理器里面看到edgetransport占用大量CPU.进入EMC的队列查看器,看到邮箱数据库堵塞,队列上万. 堵塞的邮件大多是收件 ...
- FreeMarker生成Word文档
FreeMarker简介: FreeMarker是一款模板引擎:即一种基于模板和要改变的数据,并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具,它不是面向最终用户的,而是一个 ...
- ADO.net 增删改查
ADO.net 一.定义:编程开发语言与数据库连接的一门语言技术 二.链接: 在vs中操作数据库需在开头进行链接 链接内容:using System.Data.SqlClient 三.引用数据库: 四 ...
- Linux上VNC常见命令
参考链接: http://blog.csdn.net/russle/article/details/4757888 http://www.linuxidc.com/Linux/2016-06/1320 ...
- js 只允许输入数字
<input id="credit" type="text" class="nummber" onkeyup="value= ...
- LeetCode题解 Permutations II 和 Permutations I ——回溯算法
这个算法感觉还是很陌生的.算法导论里没有讲这个算法,而数据结构与算法分析只用了一节来阐述.我居然跳过去了..尴尬. 笨方法解决的: 第一题: 给定一个元素不重复的数组,枚举出他们的全排列. 方法1:递 ...