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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.73
olegod
0 / 0 / 0
Регистрация: 04.05.2011
Сообщений: 113
#1

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

15.07.2012, 22:20. Просмотров 1427. Ответов 23
Метки нет (Все метки)

Здравствуйте, есть текст и переменная с позицией последнего клика на этом тексте, нужно найти 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++
Не правильно считает вхождение подстроки в строку,данные читаются из файлов. int _tmain() { SetConsoleCP(1251); ...

Вхождение подстроки в строку - C++
Написать функцию , котоpая находит пеpвую по поpядку позицию вхождения подстpоки в указанную пользователем стpоку , начи- ная с...

Найти последнее вхождение подстроки в строку - C++
Нужно нати последнее вхождение определенной подстроки в строку. Help!

Удалить из строки каждое вхождение подстроки - C++
Удалить из строки s каждое вхождение подстроки s1. На С++ Дублирование тем запрещено правилами форума (п. 3.4). Не плодите...

Найти первое вхождение подстроки и передать указатель - C++
Есть cимвoльная cтрока и подcтpока. Нужно найти пepвоe вхождение подстроки в строку и передать указатель на первый симвoл данного...

Функция находящее в строке заданное вхождение подстроки - C++
Описать функцию PosK(S0, S, K) целого типа, возвращающую номер позиции, начиная с которой в строке S содержится K-е вхождение подстроки S0...

Заменить в строке последнее вхождение данной подстроки на другую подстроку - C++
Даны строки s,s1 и s2. Заменить в строке S последнее вхождение строки S1 на строку S2 через char

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
olegod
0 / 0 / 0
Регистрация: 04.05.2011
Сообщений: 113
17.07.2012, 03:06  [ТС]     Ближайшее вхождение подстроки #21
Нет, 36)
alsav22
5416 / 4812 / 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++
Как можно найти вхождение подстроки в строку без строковых функций?

Написать функцию, которая возвращает указатель на первое вхождение подстроки string2 в строке string1 - C++
char* strstr(char* string1, char* string2) Возвращает указатель на первое вхождение подстроки string2 в строке string1. В случае неудачи...

Заменить каждое вхождение <i> на <курсив>, а каждое вхождение </i> на <конец курсивах> - C++
Тэг курсива. Дан текст, в котором встречаются структуры &lt;i&gt; и &lt;/i&gt;. Заменить каждое вхождение &lt;i&gt; на &lt;курсив&gt;, а каждое вхождение &lt;/i&gt;...

Найти длину максимальной подстроки, такой что в этой подстроке не существует подстроки равной какой-то строке - C++
Не могу решить задачу, я понял саму задачу. Не могу написать код, помогите, плз! У Дроида-На2а есть строка S, и K строк ai. Ваша задача...

Создать функции добавления подстроки и удаления подстроки - C++
Написать в программе функции добавления подстроки и удаления подстроки в любом месте данного рядка.


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

Или воспользуйтесь поиском по форуму:
alsav22
5416 / 4812 / 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     Ближайшее вхождение подстроки
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru