Форум программистов, компьютерный форум CyberForum.ru

Ближайшее вхождение подстроки - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.73
olegod
0 / 0 / 0
Регистрация: 04.05.2011
Сообщений: 113
15.07.2012, 22:20     Ближайшее вхождение подстроки #1
Здравствуйте, есть текст и переменная с позицией последнего клика на этом тексте, нужно найти 2 ближайших вхождения определённой подстроки(слева и справа). Вот что у меня получилось:
C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//clipboard строка const char*, c - позиция последнего клика в int
   int i = 0;
   int p1;
   int p2;
 while(true) {
  if(p1 != 0 and (clipboard[c - i] == ';' || clipboard[c - i] == '\n'))
      p1 = c - i;
  if(p2 != 0 and (clipboard[c + i] == ';' || clipboard[c + i] == '\n'))
      p2 = c + i;
if(p1 != 0 and p2 != 0)
    break;
 
i++;
}
Но такой код не работает, он возвращает огромные числа, помогите исправить или найти более правильное решение. Заранее спасибо!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.07.2012, 22:20     Ближайшее вхождение подстроки
Посмотрите здесь:

C++ Удалить из строки каждое вхождение подстроки
найти последнее вхождение подстроки в строку C++
Мне надо сделать поиск последнего вхождения подстроки s1 в строку s(с функцией LastPos, не strstr). В этом коде просто вхождение подстроки в строку. C++
C++ Вхождение подстроки в строку
C++ Как можно найти вхождение подстроки в строку без строковых функций?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
olegod
0 / 0 / 0
Регистрация: 04.05.2011
Сообщений: 113
17.07.2012, 03:06  [ТС]     Ближайшее вхождение подстроки #21
Нет, 36)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
17.07.2012, 03:20     Ближайшее вхождение подстроки #22
Только сейчас увидел. У вас dBuf где объявлен? И что у вас за aBuf ?

Добавлено через 5 минут
Цитата Сообщение от olegod Посмотреть сообщение
Нет, 36)
36 и 47 - это так один символ пропускает? Смеётесь?
olegod
0 / 0 / 0
Регистрация: 04.05.2011
Сообщений: 113
17.07.2012, 03:24  [ТС]     Ближайшее вхождение подстроки #23
Извиняюсь, string там дописать забыл, ну я бы не скомпилировал код с такой ошибкой. Проблема видимо в кодировке т.к. такой код:
C++ (Qt)
1
2
3
string testStr = "тест";
int testInt = testStr.size();
cout << testInt;
Выдаёт 8, кодировка стоит UTF-8, у вас наверняка CP1251
Как-то можно с такой проблемой бороться без смены кодировки? Проблематично её менять
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.07.2012, 16:24     Ближайшее вхождение подстроки
Еще ссылки по теме:

C++ вхождение подстроки в строку
C++ Найти первое вхождение подстроки и передать указатель
Функция находящее в строке заданное вхождение подстроки C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
17.07.2012, 16:24     Ближайшее вхождение подстроки #24
Цитата Сообщение от olegod Посмотреть сообщение
Извиняюсь, string там дописать забыл, ну я бы не скомпилировал код с такой ошибкой. Проблема видимо в кодировке т.к. такой код:
C++ (Qt)
1
2
3
string testStr = "тест";
int testInt = testStr.size();
cout << testInt;
Выдаёт 8, кодировка стоит UTF-8, у вас наверняка CP1251
Как-то можно с такой проблемой бороться без смены кодировки? Проблематично её менять
Задайте вопрос на форуме.

Добавлено через 12 часов 9 минут
Если Юникод, то тогда нужно в коде string заменить на wstring, cout на wcout. Если есть строка в "" или символ в ' ', то перед ней поставить L :wstring clipboard = L"login;pass\nlogin1;pass1\nlogin2;pass2\nлогин;пасс\nлогин1;пасс1\n";
И str_format() - это что?
Yandex
Объявления
17.07.2012, 16:24     Ближайшее вхождение подстроки
Ответ Создать тему
Опции темы

Текущее время: 07:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru