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

Линейный поиск в массиве

18.03.2019, 09:39. Показов 1448. Ответов 1

Студворк — интернет-сервис помощи студентам
Адекватно не работает линейный поиск, при вводе любого элемента, кроме первого, выводит результат как на картинке.
В чем проблема?

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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
// lab10.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#include <ctime>
#include <iomanip>
 
using namespace std;
 
void arraygen(float* arr, int num);
void BubbleSort(float *mas, int i);
void arraycout(float* arr, int num);
int linSearch(float* arr, float requiredKey, int num);
void ChoiceSort(float* array, int size);
 
int main() {
    int choice = 0; // будет хранить выбор пользователя
    bool var = true; // управляющая переменная цикла do while
    int num; // размер массива
    int nElement = 0; // номер элемента массива
    cout << "Enter integer value: ";
    cin >> num; //получение от пользователя размера массива
    float *arr = new float[num]; // Выделение памяти для массива
    cout << "\nYour array is: ";
    arraygen(arr, num); //ген масива
    arraycout(arr, num); //вывод масива
    cout << "\n\nHow to sort array?";
    cout << "\n1 - Bubble sort";
    cout << "\n2 - Choice sort";
    cout << "\nYour choice is ";
    do {
        cin >> choice; // ввод значения
        cout << endl;
        switch (choice) // switch принимает переменную answer и ищет подходящий case
        {
        case 1:  // если choice равно 1, на экран выйдут сообщения этого case           
            BubbleSort(arr, num);//сортування
            cout << endl << "Bubble sort: ";
            arraycout(arr, num);
            break; // выход из switch. иначе будет переход case(2)  и т.д.
        case 2: // если choice равно 2     
            ChoiceSort(arr, num);
            cout << endl << "\nChoice sort: ";
            arraycout(arr, num);
            break;
        default: // если ни один case не сработал, сработает default
            cout << "Incorrect choice! ";
            cout << "Do the right choice: ";
        }
        // если введено правильное значение (от 1 до 2)
        // default не сработает и выполнится блок if
        // переменная var примет значение false
        // и цикл do while не повторится
        if (choice >= 1 && choice <= 2)
            var = false;
    } while (var); //цикл повторится, пока var не изменит значение на false
 
    cout << endl << "\nEnter key of num: ";
    float requiredKey = 0.0;
    cin >> requiredKey; // ввод искомого числа
                        //поиск искомого числа и запись номера элемента
    nElement = linSearch(arr, requiredKey, num);
        if (nElement != -1)
    {
        //если в массиве найдено искомое число - выводим индекс элемента на экран
        cout << "Value " << requiredKey << " is in the cell with the index: " << nElement << endl;
    }
    else
    {
        //если в массиве не найдено искомое число
        cout << "There is no such value in the array." << endl;
    }
    //delete[] arr; // очистка памяти
    _gettch();
    return 0;
}
 
void arraygen(float* arr, int num)
{
    srand(time(NULL));
    for (int i = 0; i < num; i++) {
        // Заполнение массива и вывод значений его элементов
        arr[i] = float(rand() / 100.0 - 100.0);//диапазон чисел [-1000; 1000] с двумя знаками после запятой
    }
}
 
void arraycout(float* arr, int num)
{
    for (int i = 0; i < num; i++) {
        // Заполнение массива и вывод значений его элементов
        if (i % 10 == 0) cout << endl;
        cout << arr[i] << " "; 
    }
}
 
int linSearch(float* arr, float requiredKey, int num)
{
    
    float epsilon = numeric_limits<float>::epsilon();
    if (fabs(arr[num] - requiredKey) < epsilon) {
        for (int i = 0; i < num; i++)
        {
            if (arr[i] == requiredKey)
                return i;
        }
        return -1;
    }
}
 
 
void BubbleSort(float *mas, int i) //rabotaet
{
    for (int k = 0; k<i - 1; k++)
        for (int j = k + 1; j<i; j++)
            if (mas[k]<mas[j])
                swap(mas[k], mas[j]);
}
 
 
void ChoiceSort(float* array, int size)
{
    for (int i = 0; i < size - 1; i++) {
        /* устанавливаем начальное значение минимального индекса */
        int min_i = i;
        /* находим индекс минимального элемента */
        for (int j = i + 1; j < size; j++) {
            if (array[j] < array[min_i]) {
                min_i = j;
            }
        }
        /* меняем значения местами */
        float temp = array[i];
        array[i] = array[min_i];
        array[min_i] = temp;
    }
}
Миниатюры
Линейный поиск в массиве  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.03.2019, 09:39
Ответы с готовыми решениями:

Линейный поиск в массиве
Подскажите пожалуйста ,что нужно сделать для реализации линейного поиска в данном массиве? Буду очень признателен. #include...

Линейный поиск в массиве структуры
Нужно с помощью линейного поиска искать в готовом массиве структуры значение вводимое с клавиатуры. Напишите шаблон , по которому это можно...

Линейный поиск в массиве и списке
Добрый день, дорогие форумчане! Имеется программа, которая должна выполнять линейный поиск по ключу в массиве и списке, но функция поиска...

1
 Аватар для FFPowerMan
2156 / 1236 / 508
Регистрация: 11.10.2018
Сообщений: 6,257
18.03.2019, 10:48
Сортировка выбором называется SelectSort, а не ChoiceSort.

Добавлено через 27 минут
Цитата Сообщение от Starykh Посмотреть сообщение
C++
1
if(fabs(arr[num] - requiredKey) < epsilon)
- вот ошибка. arr[num] - обращение к несудествующему элементу массива, потому что если элементов в массиве num, то последний элемент будет (num-1). Если Вы хотите найти какой-то элемент в массиве, то надо организовать цикл for() - проход по всем элементам массива.
Кстати, с такой epsilon, как высветилось у меня = 1e-7 он никогда не найдет требуемый элемент. Там где-то нужно точность = 1e-5.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.03.2019, 10:48
Помогаю со студенческими работами здесь

Сортировка, линейный и бинарный поиск в массиве
1. Ввести элементы массива Х(15). 2. Ввести значение целевого элемента (А). 3. Найти А с помощью алгоритма линейного поиска. 4....

Линейный поиск в массиве действительных чисел
Не работает поиск и иногда выводит числа с более чем 2 числами после запятой Что делать? // lab10.cpp: определяет точку входа для...

Линейный поиск в массиве действительных чисел
Не работает поиск и иногда выводит числа с более чем 2 числами после запятой Что делать? #include &quot;stdafx.h&quot; #include...

Линейный поиск в массиве double чисел
При попытке найти номер элемента в массиве с double чисел, каждый раз получаю что элемента не существует. Пробовал вводить число со...

Линейный поиск с барьером в массиве структур (С++)
Здравствуйте! Помогите , пожалуйста , разобраться с поиском . Вот я создаю структуру : struct D //описываемая струтура { ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru