|
0 / 0 / 0
Регистрация: 14.09.2022
Сообщений: 15
|
||||||
Двоичный поиск. Почему-то индекс выводится на 1 меньше, не понимаю почему(29.09.2022, 10:59. Показов 687. Ответов 7
Метки нет (Все метки)
0
|
||||||
| 29.09.2022, 10:59 | |
|
Ответы с готовыми решениями:
7
Не понимаю почему не выводится ответ
|
|
884 / 537 / 228
Регистрация: 21.02.2011
Сообщений: 5,705
|
|
| 29.09.2022, 11:06 | |
|
ну допустим в массиве 5 чисел
1 2 3 4 5 если вам нужно найти число 3, то его индекс будет 2, так как счет идет от 0, в этом же ваш вопрос был?
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 29.09.2022, 11:09 | ||
|
У вас, кстати, алгоритм поиска неправильно реализован. Что будет, если искомого числа в массиве нет?
0
|
||
|
0 / 0 / 0
Регистрация: 14.09.2022
Сообщений: 15
|
|
| 29.09.2022, 11:22 [ТС] | |
|
да, но, если массив будет: 8 1 2 3 4 5 9 4 6, (я ищу число 4), то индекс будет = 3, а должен быть 4
также и с другими массивами, например: 6 9 0 4 3 7 1, (я ищу 4), индекс = 2, а не 3 Добавлено через 10 минут это закономерная ошибка, не понимаю, где вычитается эта единица, а может индекс идет не с 0, а с -1 или еще как-то... Уже не знаю как еще проверить
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 29.09.2022, 11:23 | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 14.09.2022
Сообщений: 15
|
|
| 29.09.2022, 11:24 [ТС] | |
|
ааа, то есть, я сначала должна отсортировать его по возрастанию, например, пузырьковой сортировкой, а потом искать индекс, да?
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|
| 29.09.2022, 11:30 | |
|
Albina_saf, разумеется.
В .NET есть готовый метод Array.Sort.
0
|
|
|
0 / 0 / 0
Регистрация: 14.09.2022
Сообщений: 15
|
|
| 29.09.2022, 13:33 [ТС] | |
|
сейчас заработало правильно . Но когда я хочу, чтобы у меня выводились индексы всех повторяющихся цифр в массиве, этого не происходит. Также не смогла сделать условие, что если нет цифры в массиве - вывести соответствующее сообщение
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace двоичный_поиск { internal class Program { static void Main(string[] args) { Console.Write("сколько чисел в маасиве? "); int[] Array = new int[Convert.ToInt32(Console.ReadLine())]; for (int i = 0; i < Array.Length; i++) { Array[i] = Convert.ToInt32(Console.ReadLine()); } for (int i = 0; i < Array.Length; i++) { for (int j = 0; j < Array.Length - 1 - i; j++) { if (Array[j] > Array[j + 1]) { int tmp = Array[j]; Array[j] = Array[j + 1]; Array[j + 1] = tmp; } } } for (int i = 0; i < Array.Length; i++) { Console.Write($"{Array[i]} "); } int low = 0; int high = Array.Length-1; int index = 0; int count = 0; Console.Write("\nwhich number do you want to find? "); int FindNum = Convert.ToInt32(Console.ReadLine()); while (Array[index] != FindNum) { index = (high + low) / 2; if (FindNum < Array[index]) high = index - 1; else if (FindNum > Array[index]) low = index + 1; else if (Array[index] == FindNum) count++; } Console.WriteLine("index of num = " + index); Console.ReadKey(); } } }
0
|
|
| 29.09.2022, 13:33 | |
|
Помогаю со студенческими работами здесь
8
Почему выводится в виде таблицы и почему не работает сортировка
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|