Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > .NET Frameworks (точка нет фреймворки) > C# (си шарп)
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 10.12.2011, 17:31   #1
vilix
Пользователь
 
Регистрация: 04.06.2009
Сообщений: 10
Восклицание алгоритм анаграмм(оптимизировать)

Задача такова, есть словарь на 100+ тысяч слов, нужно проверить каждое слово в нем на его анаграммы, в этом же словаре. не используя linq. Можно использовать sql ( предпочтения преподавателя) но мол лучше всего стандартными средствами.
Я задачу то выполнил но выполняет он её за 2 минуты 15 секунд, хотя запрос на линку делает это за 1 секунду..

вот код(можно вставить сразу в linqpad) :

Код:
void Main()
{
    s = st.ToList();
            for (int i = 0; i < s.Count; i++)
            {
                s2.Add(chrtostr((s[i].ToCharArray().OrderBy(x => x).ToArray()))) ;
                
            }
            
          
           
            while(s.Count!=0)
            {
                ann = ScanAnn(s2[0]);
                if (ann.Count > 3){
                    for (int i = 0; i < ann.Count; i++)
                    
                        Console.Write(ann[i] + ' ');
                        Console.WriteLine();
                    }
            } 
}
// Define other methods and classes here
  static string chrtostr(char[] value)
        {
            /*
             *
             * Faster way to convert char to string.
             *
             * */
            return new string(value);
        }
        static   List<string> s = new List<string>();
         static   List<string> s2 = new List<string>();
          static  List<string> ann = new List<string>();
           static  string[] st= (File.ReadAllLines("c:\\words.txt"));
           
        static List<string> ScanAnn(string fstr)
        {
            List<string> ann = new List<string>();
            int inx;
            do
            {
                inx = s2.IndexOf(fstr);
                if (inx != -1)
                {
                    ann.Add(s[inx]);
                    s.RemoveAt(inx);
                    s2.RemoveAt(inx);
                }
            }
            while (inx != -1);
            return ann;
        }
если нужно скину словарь
vilix вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Asm: как оптимизировать алгоритм? bagfinder Помощь студентам 0 03.04.2011 12:28
Оптимизировать программу phenix Помощь студентам 1 15.12.2010 01:53
Программа поиска анаграмм C# Arnezami C# (си шарп) 5 25.11.2010 14:41
Нахождение слов-анаграмм, Ошибка выдается. Задание внутри. Код внутри. TYMON Общие вопросы .NET 2 22.11.2010 21:07
Оптимизировать алгоритм вычисления сумм элементов главной и побочной диагонали в матрице - Delphi r9m Помощь студентам 5 04.02.2009 11:01