0

通过输入段落尝试 Anagram 检查器,输出清晰,但内存限制超过指定

这是我尝试过的代码

using System;

class Program
{
    static void Main(string[] args)
    {

        string[] arr = (Punct(Console.ReadLine()).ToLower()).Split(' ');
        string a = string.Empty;
        System.Collections.Generic.Dictionary<string, string> dn = new System.Collections.Generic.Dictionary<string, string>(); // *2
        foreach (string s in arr)
        {
            string st = sort(s);
            if (dn.ContainsKey(st))
            {
                if (dn[st] != s)
                {
                    if (a.Contains(dn[st]))
                        a = a.Replace(dn[st], dn[st] + " " + s); // *1
                    else
                        a = a + dn[st] + " " + s + "\n";
                    dn[st] = s;
                }
            }
            else
                dn.Add(st, s);
        }
        Console.Write(a);
    }

    public static string sort(string s)
    {
        char[] chars = s.ToCharArray();
        Array.Sort(chars);
        return new string(chars);
    }

    public static string Punct(string s)
    {
        System.Text.StringBuilder sb = new System.Text.StringBuilder();
        foreach (char c in s)
        {
            if (!char.IsPunctuation(c))
                sb.Append(c);
        }
        return sb.ToString();
    }
}

在使用探查器检查时,字符串函数也需要大量内存和其他字典,所以,我的问题是如何将上述代码优化到最少的内存,或者我使用的任何代码或声明都是不必要的?

输入:

世界部分地区在夏季有近 24 小时的阳光。丹的头上戴着一条带子,以表明自己是领导者,他想知道他面前摆着什么样的陷阱。

输出:

零件带陷阱
丹和

4

2 回答 2

2

我注意到几点:

  • 不是将整个文件加载到内存中,而是逐字读取。它可能会使事情变得更复杂,但会减少大文件的内存。并不重要,例如您提供的文本。
  • 而不是累积结果输出(在a中),只需将单词保存在字典本身中,可能在列表中,并在运行整个文件后输出。
  • 尝试使用基数树而不是使用字典。

我认为我的第二点在你的情况下是最重要的。如果您有更大的文件和更多不同的单词,但第 1 点和第 3 点将很重要,但相同字谜的“命中”最少。

于 2013-08-06T05:32:48.103 回答
0

尽量减少字符串操作,尤其是没有 StringBuilder 的连接。另外,只需使用 C# LINQ 技术:

string input = Console.ReadLine();
string[] words = (Punct(input).ToLower()).Split(' ');

var anagramStrings = words
    .Distinct()
    .GroupBy(sort)
    .Where(anagrams => anagrams.Count() > 1)
    .Select(anagrams => String.Join(" ", anagrams));

string output = String.Join("\n", anagramStrings);

Console.Write(output);
于 2013-08-06T07:13:33.360 回答