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

Найти ближайший элемент.

26.10.2009, 18:55. Показов 3928. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Написать функцию нахождения в массиве целых чисел элемента, ближайшего к значению второго фргумента типа int.. заранее благодарю
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.10.2009, 18:55
Ответы с готовыми решениями:

Найти элемент двухмерного массива, ближайший к числу
Помогите подправить программу: Найти элемент двухмерного массива, ближайший к числу -2, и его индексы. двухмерный массив целых чисел...

Найти элемент последовательности ближайший к заданному числу
Есть задача, не понимаю что как делать Дана последовательность вещественных чисел a1,a2, ... , a15 упорядоченная по возрастанию, и...

Найти элемент последовательности (его порядковый номер и значение), ближайший к n
я не прошу код(но не откажусь). Хотя бы с чего мне начать подскажите задача: Дана последовательность вещественных чисел а1,а2, ..а15,...

7
эволюционирую потихоньку
 Аватар для TanT
468 / 466 / 91
Регистрация: 30.06.2009
Сообщений: 1,401
26.10.2009, 19:31
я экспериментировал на флоат, можешь шаблоны ваабще убить коли не понятно и переделать под свои условия


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
#include <iostream>
#include <cmath>
 
using namespace std;
 
 
template<class T, class TT>
T findNearestValue(T arr[], int n, TT findVal)
{ 
    TT temp=abs(findVal-(TT)arr[0]);
    T unknouwn=arr[0]; 
 
    for (int i=1; i<n; i++)
    {
        if(abs(findVal-(TT)arr[i])<temp)
        {
            temp=abs(findVal-(TT)arr[i]); unknouwn=arr[i];
        }
    }
    
    return unknouwn;
}
 
void main()
{ 
    int arrayN[ ]={10,9,2,3,4,6,8,5,10,9, 10};
    int count = sizeof(arrayN)/sizeof(int);
    float temp=5.5;
    cout<<"Nearest Value to ("<<temp<<") "<<findNearestValue(arrayN, count, temp);
    cout<<endl; system("pause");
}
0
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
01.11.2009, 18:56  [ТС]
А можно на С,а то на С++ я пока еще не понимаю)
0
425 / 229 / 87
Регистрация: 25.03.2009
Сообщений: 744
01.11.2009, 20:18
убей шаблоны(то есть функция будет выглядеть как обычная и допустим если массив с целыми значениями везде вместо T поставь - int вывод сделай как printf(...)
0
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
02.11.2009, 22:17  [ТС]
Так говорю честно,для меня язык программирвания как японский,знаки видел но не понимаю.Можно мне объяснить как это программа работает.А то такими темпами я ни чему не научусь.Спсиба.
0
10 / 10 / 2
Регистрация: 01.11.2009
Сообщений: 67
02.11.2009, 22:59
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
#include <iostream>
#include <cmath>
 
using namespace std;
 
 
int findNearestValue(int arr[], int n, int findVal)
{ 
    int temp=abs(findVal-(int)arr[0]);
    int unknouwn=arr[0]; 
    
    for (int i=1; i<n; i++)
    {
        if(abs(findVal-(int)arr[i])<temp)
        {
            temp=abs(findVal-(int)arr[i]); unknouwn=arr[i];
        }
    }
    
    return unknouwn;
}
 
int main()
{ 
    int arrayN[ ]={10,9,2,3,4,6,8,5,10,9, 10};
    int count = sizeof(arrayN)/sizeof(int);
    float temp=5.5;
    printf("Answer: %d", findNearestValue(arrayN, count, temp));
    system("pause");
}
0
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
04.11.2009, 15:08  [ТС]
Спасиба за труды.Но можно написать какие действия выполняються у каждого оператора.
0
62 / 62 / 33
Регистрация: 14.01.2014
Сообщений: 145
02.02.2014, 03:44
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
#include <iostream>
 
using namespace std;
 
const int size = 5;
 
int findNearestValue(int arr[], int n, int findVal = 0)
{ 
    int temp = abs( findVal - arr[0] );
    int res = arr[0]; 
 
    for (int i = 1; i < n; i++)
    {
        if( abs( findVal - arr[i] ) < temp )
        {
            temp = abs( findVal - arr[i] ); 
            res = arr[i];
        }
    }
    return res;
}
 
int main()
{
    int mas[size];  
    for (int i = 0; i < size; i++)
    {
        cout << " vvedite chislo" << i + 1 << endl;
        cin >> mas[i];
    }
    int max = mas[0], min = mas[0];
    for (int i = 1; i < size; i++)
    {
        if (mas[i] > max) max = mas[i];
        if (mas[i] < min) min = mas[i];
    }
    
    cout << "max =" << max << "\nmin =" << min << endl;
    cout << "nearest value to 0 = " << findNearestValue(mas, size) << endl;
    system("pause");
        
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.02.2014, 03:44
Помогаю со студенческими работами здесь

Найти в массиве ближайший по значению элемент меньший заданного числа
Добрый день, господа. Помогите пожалуйста с решением задачи. Дано некоторое число А. Найти в целочисленном массиве В из N элементов...

Найти элемент массива ближайший к заданному числу. Если таких чисел несколько, вывести наименьшее из них
Если с основным условием я справился, то с уточнением не могу. Вышло это: #include &lt;iostream&gt; #include...

В массиве каждый элемент заменить на ближайший следующий за ним элемент, который больше его
Помогите выполнить лабу на с++ Само задание: В таблице А размера N за один просмотр необходимо каждый элемент заменить на ближайший...

Каждый элемент заменить на ближайший следующий за ним
Добрый день. В таблице А размера N за один просмотр необходимо каждый элемент заменить на ближайший следующий за ним элемент, который...

Определить в последовательности элемент, ближайший к какому-нибудь целому
Даны натуральные числа N и последовательность А1,А2,...,A N. Определить ближайшее к какому-нибудь целому. Добавлено через 5 часов 45...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru