Chinaunix首页 | 论坛 | 博客
  • 博客访问: 349944
  • 博文数量: 25
  • 博客积分: 3011
  • 博客等级: 中校
  • 技术积分: 367
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-28 13:22
个人简介

生命在于折腾

文章分类

全部博文(25)

文章存档

2015年(1)

2011年(3)

2010年(4)

2009年(17)

我的朋友

分类: 敏捷开发

2009-09-25 18:00:32

今天有人在群里问了这样一个问题,一个内表有2个字段:f1和f2,每个条目代表物料f1消耗了f2。有一种可能是,f1消耗了f2,f2直接或间接又消耗了f1,形成一种递归关系。
现在希望找出内表中所有的这种物料,因为这些物料对成本分摊有不良影响。比如:[a,b] [b,c] [a,d] [b,d] [c,a];则结果包含a,b,c,不包含d。乍一看需求有点晕,仔细一想,其实就是将内表中所有条目,两两之间进行运算而已。
程序思路:每次取内表中的一个条目,将它与内表中位于其前面的所有条目进行运算;运算过程中,如果生成了新对应关系,则将其添加到内表后面(也等待着与内表中所有条目进行运算);如此循环……等到内表循环结束,所有可能的对应关系,自然都被考虑到了。

DATABEGIN OF wa1,
        f1 TYPE c,
        f2 TYPE c,
      END OF wa1.

DATA: wa2 LIKE wa1,
      tabix LIKE sy-tabix,
      itab LIKE TABLE OF wa1 WITH HEADER LINE,
      itab2 TYPE TABLE OF c WITH HEADER LINE.

itab-f1 = 'a'.
itab-f2 = 'b'.
APPEND itab.
itab-f1 = 'b'.
itab-f2 = 'c'.
APPEND itab.
itab-f1 = 'a'.
itab-f2 = 'd'.
APPEND itab.
itab-f1 = 'b'.
itab-f2 = 'd'.
APPEND itab.
itab-f1 = 'c'.
itab-f2 = 'a'.
APPEND itab.

LOOP AT itab INTO wa1.
  tabix = sy-tabix - 1.
  LOOP AT itab INTO wa2 TO tabix.
    IF wa2-f2 = wa1-f1. "运算一
      READ TABLE itab WITH KEY
        f1 = wa2-f1 f2 = wa1-f2.
      IF sy-subrc <> 0.
        IF wa2-f1 = wa1-f2.
          APPEND wa2-f1 TO itab2. "存到结果表
        ELSE.
          itab-f1 = wa2-f1.
          itab-f2 = wa1-f2.
          APPEND itab. "添加新对应关系到内表
        ENDIF.
      ENDIF.
    ENDIF.
    IF wa2-f1 = wa1-f2. "运算二
      READ TABLE itab WITH KEY
        f1 = wa1-f1 f2 = wa2-f2.
      IF sy-subrc <> 0.
        IF wa1-f1 = wa2-f2.
          APPEND wa1-f1 TO itab2. "存到结果表
        ELSE.
          itab-f1 = wa1-f1.
          itab-f2 = wa2-f2.
          APPEND itab. "添加新对应关系到内表
        ENDIF.
      ENDIF.
    ENDIF.
  ENDLOOP.
ENDLOOP.

SORT itab2.
DELETE ADJACENT DUPLICATES FROM itab2.
LOOP AT itab2. "输出结果表
  WRITE: / itab2.
ENDLOOP.
LOOP AT itab. "输出所有对应关系作参考
  WRITE: / itab-f1, itab-f2.
ENDLOOP.

程序运行过程:
1,[a,b][b,c][a,d][b,d][c,a],他们相互间运算完毕后,生成了新对应关系[a,c][c,b][b,a][c,d];
2,[a,c][c,b][b,a][c,d]这些新对应关系与老对应关系两两运算,同时相互间也两两运算,生成了新对应关系[c,c][a,a][b,b]。这是特殊的对应关系(即递归关系),它们不需要重新参与运算,直接写到了我们的结果表。
由于没有新对应关系的生成,程序运行完毕,结果表中形成了a,b,c三条记录。
阅读(4150) | 评论(4) | 转发(1) |
给主人留下些什么吧!~~

chinaunix网友2009-10-19 14:00:56

对你的景仰有如滔滔江水连绵不绝......

chinaunix网友2009-10-17 15:13:27

yun le

flfn2009-09-27 14:01:17

学习~

chinaunix网友2009-09-26 11:20:34

阿甘哥,实在太强。。。。。。仰视一下。