Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Поиск слова в строке на кириллице  (Прочитано 11587 раз)
0 Пользователей и 4 Гостей смотрят эту тему.
Tenzor
Интересующийся

ru
Offline Offline

« : 28-07-2012 12:55 » 

Здравствуйте. Есть такой код:
Код: (C++)
 setlocale( LC_CTYPE, "rus" );
//Забираем 18 строку из RichTextBox находящегося в CDialog
        int LineIndex;
        int LineLength;
        int y=18;
        char *GS;
        size_t found;
        string str;
        LineIndex=SendMessageA(dlgEdit,EM_LINEINDEX,(WPARAM)y,0);
        LineLength=SendMessageA(dlgEdit,EM_LINELENGTH,(WPARAM)LineIndex,0);
        GS=new char[LineLength];
        GS[LineCount]='\0';
        *(DWORD*) GS=LineLength;
        SendMessageA(dlgEdit,EM_GETLINE,(WPARAM)y,(LPARAM)GS);
//Строка выглядит примерно так "           Тип опоры:                                            скользящая"
//Надо найти слово в полученной строке.
// Следующие 2 метода не работают, видимо, потому что строка и слово на кириллице.

        if(strncmp(GS,"скользящая", 10)==0)cout<<"Found"<<endl;
        else cout<<"Not found!!"<<endl;
              str=string(GS);
        found=str.find("скользящая");
        if(found!=string::npos) cout<<"Find sk"<<endl;
        else cout<<"Not Found sk"<<endl;

Есть идея разбить  строку через strtok
Код: (C++)
char chFind[]="скользящая";
char *chWord;
chWord=strtok(GS," ");
while(chWord!=NULL){
         int x=0;
         for(x;x=strlen(chFind)-1;x++){
                if(chWord[x]==chFind[x]) continue;
                else break;
               
         }
         if(x==stelen(chFind)-1) break; // Нашли.
         chWord=strtok(NULL," ");
}

Но вопрос в том, что наверняка есть менее топорное решение. К тому же слов для сравнения будет больше 10 и, что мне для каждого вызывать такой ужас?
Записан
Finch
Спокойный
Администратор

il
Offline Offline
Пол: Мужской
Пролетал мимо


« Ответ #1 : 28-07-2012 13:19 » new

Можно использовать std::map.
Записан

Не будите спашяго дракона.
             Джаффар (Коша)
Tenzor
Интересующийся

ru
Offline Offline

« Ответ #2 : 28-07-2012 13:25 » 

Для попарного сравнения?
Записан
Finch
Спокойный
Администратор

il
Offline Offline
Пол: Мужской
Пролетал мимо


« Ответ #3 : 28-07-2012 17:39 » 

Он сам ишет слово в своем словаре и выдает тебе индекс, к которому ты привязал слово. Ишет довольно быстро. Давно с ним не работал, так что можно просто посмотреть в спецификации. Но насколько я помню, если слово не находится в словаре, то выход будет равен std::map<std::string, int>.end().
« Последнее редактирование: 28-07-2012 17:43 от Finch » Записан

Не будите спашяго дракона.
             Джаффар (Коша)
RXL
Технический
Администратор

Offline Offline
Пол: Мужской

WWW
« Ответ #4 : 29-07-2012 07:38 » 

Добавлю, что проверку существования ключа надо делать через find (как раз он и вернет end() при отсутствии), а не через индекс "[]" (при отсутствии элемента он автоматически создастся, даже при попытке чтения).

Код: (C++)
#include <iostream>
#include <map>

typedef std::map <std::string, bool> dictionary_t;
//...
dictionary_t words;
dictionary_t::iterator it;
// ...

it = words.find("hello");

if (it == words.end())
  // нет слова - добавим
  words["hello"] = true;
else
  // есть - выводим
  std::cout << it->first << std::endl;
« Последнее редактирование: 29-07-2012 07:46 от RXL » Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
Tenzor
Интересующийся

ru
Offline Offline

« Ответ #5 : 30-07-2012 05:17 » 

Спасибо большое!!! Проблема решена)
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines