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

Двоичный поиск. Почему-то индекс выводится на 1 меньше, не понимаю почему(

29.09.2022, 10:59. Показов 687. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
41
42
43
44
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.WriteLine("сколько чисел в маасиве?");
            int[] Array = new int[Convert.ToInt32(Console.ReadLine())];
 
 
            for (int i = 0; i < Array.Length; i++)
            {
                Array[i] = Convert.ToInt32(Console.ReadLine());
            }
            int low = 0;
            int high = Array.Length-1;
            int index = 0;
            Console.WriteLine("which number do you want to find? ");
            int FindNum = Convert.ToInt32(Console.ReadLine());
 
            for (int i = 0; i < Array.Length; i++)
            {
                while (Array[index] != FindNum)
                {
                
                    index = (high + low) / 2;
                    if (FindNum < Array[index])
                        high = index - 1;
                    else if (FindNum > Array[index])
                        low = index + 1;                    
                }
 
            }
            Console.WriteLine("index of num = " + index);
            Console.ReadKey();
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2022, 10:59
Ответы с готовыми решениями:

Не понимаю почему не выводится
Я хотел попробовать создать скрипт, который рандомно создает 3-6 значное число, где числа будут от 0 до 9, и вроде как сделал, но что-то...

Не понимаю почему не выводится ответ
Не понимаю почему не выводится ответ . В результате должно получатся координаты в которых они пересекаются

Не понимаю почему не выводится результат программы
Здравствуйте ! Программа запускается, но результат не выводится и я не понимаю почему. Функция должна вывести результат примера 3.14 *...

7
 Аватар для andrey_f
884 / 537 / 228
Регистрация: 21.02.2011
Сообщений: 5,705
29.09.2022, 11:06
ну допустим в массиве 5 чисел
1 2 3 4 5
если вам нужно найти число 3, то его индекс будет 2, так как счет идет от 0,
в этом же ваш вопрос был?
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
29.09.2022, 11:09
Цитата Сообщение от Albina_saf Посмотреть сообщение
не понимаю почему
Потому что индексирование начинается с нуля.

У вас, кстати, алгоритм поиска неправильно реализован.
Что будет, если искомого числа в массиве нет?
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
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
29.09.2022, 11:23
Цитата Сообщение от Albina_saf Посмотреть сообщение
если массив будет: 8 1 2 3 4 5 9 4 6
То двоичный поиск неприменим, т.к. он работает только с отсортированными массивами.
0
0 / 0 / 0
Регистрация: 14.09.2022
Сообщений: 15
29.09.2022, 11:24  [ТС]
ааа, то есть, я сначала должна отсортировать его по возрастанию, например, пузырьковой сортировкой, а потом искать индекс, да?
0
Эксперт .NET
 Аватар для kolorotur
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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.09.2022, 13:33
Помогаю со студенческими работами здесь

Напишите программу для вычисления суммы первых 500 простых чисел. Не выводится результат, не понимаю почему
Напишите программу на C # для вычисления суммы первых 500 простых чисел не выводится результат. Помогите пожалуйста using System; ...

Бинарный поиск, не понимаю почему не работет функция
Вот условие задачи: Дан список элементы которого отсортированы по возрастанию. Используя алгоритм бинарного поиска узнать, есть ли в...

Почему выводится в виде таблицы и почему не работает сортировка
почему выводится в виде таблицы? почему не работает сортировка? и как туда можно вставить классы комнат? hotel.h #include...

Почему в int максимальное доступное значение 2147483647, почему не больше или не меньше
Почему в int максимальное доступное значение 2147483647, почему не больше или не меньше.

Растолкуйте, пожалуйста, программу. Двоичный поиск числа, если оно не найдено выводится ближайшее к нему
Как работают подчеркнутые строки? В чем их смысл? Что в них происходит? var a:array of integer;i,x,n,j,L,R,c: integer; begin ...


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

Или воспользуйтесь поиском по форуму:
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 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru