从字符串中提取单词的算法

标签 algorithm cobol

我正在使用 TELON/COBOL atm,我需要一种算法来从字符串中提取单词。 尝试搜索但找不到类似的东西。

无论如何,算法需要提取单词,并忽略空格;这是我到目前为止的内容(我为不熟悉 e 语法的人添加了评论)

WS-STRING 是输入字符串

WS-WORD-LEN是要提取的词的长度

WS-LST-WORD-P 是当前要提取的词的起始位置(在sting内)

WS-SUB1 是循环索引

PERFORM TEST BEFORE                                      
VARYING WS-SUB1 FROM 1 BY 1                              
  UNTIL WS-SUB1 > WS-STRING-LEN //loop for each char in the string, add 1 to WS-SUB1 in each itiaration                         
    EVALUATE TRUE                                        
       WHEN WS-STRING(WS-SUB1:1) = SPACES  //if the current char is a space              
            MOVE WS-SUB1              TO WS-SUB1-FRD     
            ADD  1                    TO WS-SUB1-FRD     
            IF WS-STRING(WS-SUB1-FRD:1) = SPACES  //Checks to see if the next char is a space       
                ADD  1                TO WS-LST-WORD-P   
            ELSE                                         
                MOVE WS-STRING(WS-LST-WORD-P:WS-WORD-LEN) //Substing "WS-WORD-LEN" many char from "WS-STRING" starting at "WS-LST-WORD-P" into "WS-WORD-OUT" 
                                      TO WS-WORD-OUT     
                ADD  1                TO WS-COUNT(2)     
                PERFORM Z-400-OUTPUT-WORD  //This outputs "WS-WORD-OUT" to a file.              
                MOVE WS-SUB1          TO WS-LST-WORD-P   
                MOVE 1                TO WS-WORD-LEN   
            END-IF                                     
       WHEN OTHER                                      
            ADD  1                    TO WS-WORD-LEN   
    END-EVALUATE                                       
END-PERFORM                                            
MOVE 1                               TO WS-LST-WORD-P  

这个算法有点工作,但一些输出在开始/结束时拼接。 那么关于这里有什么问题或提出更好的建议有什么想法吗?

最佳答案

你看过 UNSTRING 了吗?它似乎是为您的情况量身定做的。

MOVE 1 TO WS-SUB1
PERFORM UNTIL WS-SUB1 >= LENGTH OF WS-STRING
  UNSTRING WS-STRING DELIMITED SPACE
    INTO WS-WORD-OUT COUNT IN WS-WORD-LEN
    POINTER WS-SUB1
  END-UNSTRING
  ADD 1 TO WS-COUNT(2)
  PERFORM Z-400-OUTPUT-WORD
  ADD WS-WORD-LEN TO WS-SUB1
END-PERFORM

注意:代码只是徒手编写的、未编译和测试的。

关于从字符串中提取单词的算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11303235/

相关文章:

python - 用于确定列表中不那么频繁的值的有效算法

php - 二维装箱 : Why are my images overlapping?

algorithm - 摊销分析和竞赛题,有什么问题吗?

history - 256k 的 COBOL 程序有多复杂?

file-io - cobol Open-IO : create file if it doesn't exist

algorithm - map API : Finding the longest common path in two given paths

java - 地理位置聚类

cobol - 嵌套执行需要并且不需要结束执行

Cobol - 导入带实数的带符号数字

syntax-error - 在语法错误(COBOL)方面需要帮助