С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
#1

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

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

Написать функцию нахождения в массиве целых чисел элемента, ближайшего к значению второго фргумента типа int.. заранее благодарю
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.10.2009, 18:55
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти ближайший элемент. (C++):

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

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

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

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

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

Найти узел, имеющий ближайший к значению ключ - C++
Всем привет. Есть условие. первая часть уже решена. помогите пожалуйста найти узел, имеющий ближайший к этому значению ключ. ...

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


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
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
01.11.2009, 18:56  [ТС] #3
А можно на С,а то на С++ я пока еще не понимаю)
0
Андрейка
420 / 224 / 27
Регистрация: 25.03.2009
Сообщений: 744
01.11.2009, 20:18 #4
убей шаблоны(то есть функция будет выглядеть как обычная и допустим если массив с целыми значениями везде вместо T поставь - int вывод сделай как printf(...)
0
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
02.11.2009, 22:17  [ТС] #5
Так говорю честно,для меня язык программирвания как японский,знаки видел но не понимаю.Можно мне объяснить как это программа работает.А то такими темпами я ни чему не научусь.Спсиба.
0
audiophile
9 / 9 / 0
Регистрация: 01.11.2009
Сообщений: 67
02.11.2009, 22:59 #6
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
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
04.11.2009, 15:08  [ТС] #7
Спасиба за труды.Но можно написать какие действия выполняються у каждого оператора.
0
vovacreme
-16 / 61 / 13
Регистрация: 14.01.2014
Сообщений: 145
02.02.2014, 03:44 #8
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
02.02.2014, 03:44
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.02.2014, 03:44
Привет! Вот еще темы с ответами:

В бинарном дереве найти ближайший путь к заданному узлу - C++
В заданном непустом бинарном дереве найти длину (число ветвей) пути от корня до ближайшей вершины со значением, равным заданному....

Строки. Как найти в слове первый элемент? Второй элемент, последний элемент? - C++
как найти в слове первый элемент?Второй элемент,последний элемент.С помощью каких операторов это делается??

Найти минимальный элемент в каждой строке и из ний найти максимальный элемент - C++
надо найти минимальный элемент в каждой строке и из ний найти максимальный элемент вот мой код #include&lt;conio.h&gt; ...

Найти самый наименьший элемент в матрице, и найти сумму столбца который стоит этот наименьший найденный элемент - C++
Найти самый наименьший элемент в матрице, и найти сумму столбца который стоит этот наименьший найденный элемент Помогите ребята нужна ваша...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.