Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24

Поиск буквы бинарным поиском в тексте

31.05.2013, 20:25. Показов 3143. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте помогите пожалуйста написать программу, а то в понедельник сдавать,а я вообще не знаю как ее делать. Само задание: Дан текстовый файл из него считывается информация нужно найти букву бинарным поиском. Заранее спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.05.2013, 20:25
Ответы с готовыми решениями:

Поиздеавться над бинарным поиском
Вот у меня задание, написать алгоритм бинарного поиска числа в отсортированном по возрастанию массиве. Вот я написал. вроде бы все...

Нарезка колбасы бинарным поиском
Поварёнок Вася работает первый день. В его трудовые функции входит нарезка колбасы на кусочки различного веса. Вася пока не может отрезать...

Как можно решить бинарным поиском
Как можно найти бинарным поиском такой X что функция sum( Pi * |Xi - X|) (функция сумм от этих элементов) будет минимальным ,где Pi и Xi...

14
 Аватар для Хулиган
88 / 83 / 21
Регистрация: 08.08.2012
Сообщений: 737
31.05.2013, 20:52
бинарный поиск самому нужно реализовать или можно воспользоватся стандартным?
0
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24
31.05.2013, 21:04  [ТС]
самому
0
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
31.05.2013, 21:29
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
#include <iostream>
#include <string>
 
int main() {
  std::string s = "abcdefghijklmnop";
  int first = 0, average = 0, last = s.length() - 1;
  char ch;
  std::cout << "String: " << s << std::endl;
  std::cout << "Please enter char: ";
  std::cin >> ch;
  while(first < last) {
    average = first + (last - first) / 2;
    if(ch <= s[average])
      last = average;
    else
      first++;
  }
  
  if(s[last] == ch)
    std::cout << "Index: " << last << std::endl;
  else
    std::cout << "Not Found!" << std::endl;
  
  return 0;
}
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
01.06.2013, 09:28
Считывать из файла можете?
Считали, потом std::sort и std::binary_search
0
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24
01.06.2013, 11:37  [ТС]
В считывании то и был вопрос остальные то алгоритмы есть, а то в интренет искал, но не нашел
0
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
01.06.2013, 11:51
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
#include <fstream>
#include <string>
 
int binarySearch(std::string, char);
 
int main() {
  std::ifstream fin("file.txt");
  std::string str, tmp;
  
  while(!fin.eof()) {
    std::getline(fin, tmp);
    str.append(tmp);
  }
  fin.close();
  
  char ch;
  std::cout << "String: " << str << std::endl;
  std::cout << "Enter char: ";
  std::cin >> ch;
  
  int index = binarySearch(str, ch);
  if(ch == str[index])
    std::cout << "Index: " << index << std::endl;
  else
    std::cout << "Not found" << std::endl;
  return 0;
}
 
int binarySearch(std::string str, char ch) {
  int first = 0, average = 0, last = str.length() - 1;
  while(first < last) {
    average = first + (last - first) / 2;
    if(ch <= str[average])
      last = average;
    else
      first++;
  }
  return last;
}
0
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24
01.06.2013, 16:59  [ТС]
Спасибо, но программа работает только для одного слова, плюс ищет только одно совпадение, то есть если будет слово Good и искомой буквой будет о, то индекс выведет 1, а 2 не будет как это исправить?
0
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
01.06.2013, 17:26
Цитата Сообщение от vladislav23 Посмотреть сообщение
но программа работает только для одного слова?
Файл:
Кликните здесь для просмотра всего текста
abcde fghijkl mnopqrst uvwxyz

Бинарный поиск применяется для отсортированного массива(строки как здесь)

Добавлено через 16 минут
Я думаю что бинарный поиск лучше здесь не использовать
0
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24
02.06.2013, 15:41  [ТС]
А можете пожалуйста скинуть фрагмент кода, где идет посимвольной считывание текста в чаровый массив

Добавлено через 5 часов 45 минут
...
0
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
02.06.2013, 15:43
Цитата Сообщение от vladislav23 Посмотреть сообщение
А можете пожалуйста скинуть фрагмент кода, где идет посимвольной считывание текста в чаровый массив

Добавлено через 5 часов 45 минут
...
Здесь нету "массива чаров", здесь используется класс string
0
0 / 0 / 0
Регистрация: 28.04.2013
Сообщений: 24
02.06.2013, 18:14  [ТС]
это я понимаю, а если использовать чаровый массив его преобразовать в интовой отсортировать по ASCII кодам и там уже искать, так можно же?
0
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
02.06.2013, 18:15
Цитата Сообщение от vladislav23 Посмотреть сообщение
это я понимаю, а если использовать чаровый массив его преобразовать в интовой отсортировать по ASCII кодам и там уже искать, так можно же?
Массив уже отсортирован по ASCII кодам, он и ищет по ним
0
 Аватар для Ternsip
670 / 198 / 29
Регистрация: 10.05.2012
Сообщений: 595
02.06.2013, 18:21
Цитата Сообщение от MarVaL Посмотреть сообщение
average = first + (last - first) / 2;
а слабо вот так : average = (last + first) / 2;
1
С++ Beginner
 Аватар для MarVaL
120 / 120 / 77
Регистрация: 28.02.2013
Сообщений: 246
02.06.2013, 18:21
Цитата Сообщение от Ternsip Посмотреть сообщение
а слабо вот так : average = (last + first) / 2;
да, да)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.06.2013, 18:21
Помогаю со студенческими работами здесь

Программа с бинарным поиском чутка исправленная
Доброй всем ночи. Во время написания программы столкнулся с некоторым непониманием. Программа должна делать следующее: создаётся...

Решение уравнения окружности бинарным поиском
Здравствуйте. Как известно, уравнение окружности (X - Xc)^2 + (Y - Yc)^2 = R^2 Есть массив данных по окружностям, допустим: 1. xc =...

Найти корень числа бинарным поиском
Нужно написать код нахождения корня числа, используя бинарный поиск.

Бинарным поиском найти максимальное a такое, что a^2 +3*a+2
Задание-2 Дано целое положительное n от 1 до 10^9. Бинарным поиском найти максимальное a такое, что a^2 +3*a+2&lt;=n. ВВОД : 10 ...

Бинарным поиском найти минимальный неотрицательный элемент в массиве
Ребят, помогите, пожалуйста, написать функцию, которая будет бинарным поиском искать минимальный неотрицательный элемент в массиве


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru