|
1 / 1 / 1
Регистрация: 09.10.2014
Сообщений: 79
|
||||||
Поиск числа в двумерном массиве (бинарный поиск)12.04.2015, 20:30. Показов 18416. Ответов 8
Метки нет (Все метки)
Произвожу поиск элемента в массиве двумя способами: линейным(последовательным) поиском и бинарным(двоичным). Первый работает на ура. Второй корректно показывает есть элемент в массиве или нет. Но количество совпадений всегда по нулям. Не пойму куда счетчик подсчета совпадений правильно вставить. Приложил скрин работы.
0
|
||||||
| 12.04.2015, 20:30 | |
|
Ответы с готовыми решениями:
8
Двоичный (бинарный) поиск элемента в двумерном массиве Бинарный поиск числа в массиве
|
|
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
|
|
| 12.04.2015, 20:52 | |
|
объяви count как глобальная переменная, то есть int count=0; до int main() для int BinarSearch или используй другую, т.к ты её еще для чего то исползуешь
0
|
|
|
1 / 1 / 1
Регистрация: 09.10.2014
Сообщений: 79
|
||||||
| 12.04.2015, 21:17 [ТС] | ||||||
|
не помогло
Добавлено через 3 минуты Понял проблему, но не знаю решения. Поиск находит элемент и сразу выходит из функции, он даже не ищет совпадения. В данном коде программы совпадение всегда равно одному, если искомый элемент есть в массиве. Но как заставить искать совпадения?!
0
|
||||||
|
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
|
|
| 12.04.2015, 21:31 | |
|
Думаю для поиска и подсчета элементов в массиве не тот подход. Бинарный - способ быстро найти первый искомый элемент в отсортированном массиве, достаточно большом. А дальше искать и считать другим способом
0
|
|
|
1 / 1 / 1
Регистрация: 09.10.2014
Сообщений: 79
|
||||||
| 12.04.2015, 21:54 [ТС] | ||||||
|
Может этот вариант будет ближе?
0
|
||||||
|
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
|
|||||||||||
| 13.04.2015, 18:21 | |||||||||||
|
Вот поработал, но срабатывает бинарный поиск почему то не всегда. Иногда пропускает, иногда срабатывает правильно. Подсчет по строке когда больше одного совпадения пока не реализован.
с бинарным поиском из вики работает корректно
1
|
|||||||||||
|
1 / 1 / 1
Регистрация: 09.10.2014
Сообщений: 79
|
|
| 13.04.2015, 21:54 [ТС] | |
|
Спасибо, что отозвались на просьбу помощи в любом случае!
Позже посмотрю код детальнее, но идею сейчас уловил, и она как раз таки подходит для моей цели, спасибо еще раз
0
|
|
|
518 / 410 / 188
Регистрация: 08.04.2013
Сообщений: 1,750
|
||||||
| 14.04.2015, 07:40 | ||||||
Сообщение было отмечено Bad_Trip как решение
Решение
законченный вариант
2
|
||||||
|
0 / 0 / 0
Регистрация: 17.05.2020
Сообщений: 1
|
|
| 17.05.2020, 22:17 | |
|
#include <iostream>
using namespace std; int main() { setlocale(LC_ALL, "ru"); //Сравниваем последний элемент подмассива с ключом. Если ключ меньше , то применяем алгоритм бинарного поиска и ищем в подмассиве как в обычном массиве. const int ROW = 2; const int COL = 4; int arr1[ROW][COL]{ {0,4,5,43},{44,49,55,56} }; int last=0; int key = 43; int l = 0; int r = COL; bool flag = false; int mid; for (int i = 0; i < ROW; i++) { for (int j = (COL-1); j < COL; j++) { last=arr1[i][j]; if (key <= last) { while ((l <= r) && (flag != true)) { mid = (l + r) / 2; if (arr1[i][mid] == key) { flag = true; } if (arr1[i][mid] < key) { l = mid + 1; } else { r = mid - 1; } } cout << arr1[i][mid] << endl; return 0; } } } return 0; }
0
|
|
| 17.05.2020, 22:17 | |
|
Помогаю со студенческими работами здесь
9
Бинарный поиск числа в упорядоченном массиве Поиск минимального числа в двумерном массиве Бинарный поиск в массиве Бинарный поиск в массиве с++ Бинарный поиск в массиве Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|