首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >枚举一个阶段中的所有n元语法子词

枚举一个阶段中的所有n元语法子词
EN

Stack Overflow用户
提问于 2010-08-12 10:37:48
回答 3查看 113关注 0票数 0

有没有可以处理这个问题的现有函数?输入:A B C输出:{A},{B},{ C},{A B},{B C},{A B C}

请注意,{A C}或{C }不是有效输出。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-08-12 10:44:21

在伪代码中:

代码语言:javascript
复制
for (i=0 .. n-1) {
    for (j=i .. n-1) {
        ngrams.add(phase[i:j])
    }
}

phase[i:j]是从i开始到j结束的切片,n是长度(在本例中为3)

代码语言:javascript
复制
A B C 
0 1 2

0:0 A
0:1 AB
0:2 ABC
1:1 B
1:2 BC
2:2 C
票数 3
EN

Stack Overflow用户

发布于 2010-08-12 10:45:59

我想出来了: O(n^3)算法

代码语言:javascript
复制
public static void GenerateAllGrams(string query) {
        string[] q = query.Split(' ');
        int maxgram = q.Length;
        for (int gram = 1; gram <= maxgram; gram++) {
            for (int i = 0; i < q.Length - gram + 1; i++) {
                string current = "";
                for (int j = i; j < i + gram; j++) {
                    current += q[j] + " ";
                }
                Console.WriteLine(current.Trim());
            }
        }
    }
票数 1
EN

Stack Overflow用户

发布于 2010-08-12 11:36:58

在方案中:

代码语言:javascript
复制
(define (prefix x list)
    (if (null? list)
        nil
        (cons (cons x (car list))
              (prefix x (cdr list)))))

(define (subwords phrase)
    (if (null? phrase)
        nil
        (cons (list (car phrase))
              (cons (prefix (car phrase) (subwords (cdr phrase)))
                    (subwords (cdr phrase))))))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3464382

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档