|
1 / 1 / 1
Регистрация: 09.10.2014
Сообщений: 79
|
||||||
Поиск числа в двумерном массиве (бинарный поиск)12.04.2015, 20:30. Показов 18375. Ответов 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
Бинарный поиск числа в упорядоченном массиве Поиск минимального числа в двумерном массиве Бинарный поиск в массиве Бинарный поиск в массиве с++ Бинарный поиск в массиве Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога
SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
|
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога
Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip"
Извлеките архив и вы увидите. . .
|
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога
Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д.
Сборка примера
Скачайте. . .
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|