Форум программистов, компьютерный форум CyberForum.ru

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

Восстановить пароль Регистрация
 
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
26.10.2009, 18:55     Найти ближайший элемент. #1
Написать функцию нахождения в массиве целых чисел элемента, ближайшего к значению второго фргумента типа int.. заранее благодарю
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.10.2009, 18:55     Найти ближайший элемент.
Посмотрите здесь:

C++ Найти минимальный элемент в каждой строке и из ний найти максимальный элемент
В одномерном целочисленном массиве найти минимальные элемент m и максимальный элемент М C++
Найти узел, имеющий ближайший к значению ключ C++
Строки. Как найти в слове первый элемент? Второй элемент, последний элемент? C++
Найти самый наименьший элемент в матрице, и найти сумму столбца который стоит этот наименьший найденный элемент C++
Найти элемент двухмерного массива, ближайший к числу C++
Ближайший общий предок C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
TanT
эволюционирую потихоньку
 Аватар для TanT
464 / 462 / 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");
}
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
01.11.2009, 18:56  [ТС]     Найти ближайший элемент. #3
А можно на С,а то на С++ я пока еще не понимаю)
Андрейка
419 / 223 / 27
Регистрация: 25.03.2009
Сообщений: 744
01.11.2009, 20:18     Найти ближайший элемент. #4
убей шаблоны(то есть функция будет выглядеть как обычная и допустим если массив с целыми значениями везде вместо T поставь - int вывод сделай как printf(...)
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
02.11.2009, 22:17  [ТС]     Найти ближайший элемент. #5
Так говорю честно,для меня язык программирвания как японский,знаки видел но не понимаю.Можно мне объяснить как это программа работает.А то такими темпами я ни чему не научусь.Спсиба.
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");
}
AlexAD
0 / 0 / 0
Регистрация: 26.10.2009
Сообщений: 4
04.11.2009, 15:08  [ТС]     Найти ближайший элемент. #7
Спасиба за труды.Но можно написать какие действия выполняються у каждого оператора.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.02.2014, 03:44     Найти ближайший элемент.
Еще ссылки по теме:

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

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

Или воспользуйтесь поиском по форуму:
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");
        
}
Yandex
Объявления
02.02.2014, 03:44     Найти ближайший элемент.
Ответ Создать тему
Опции темы

Текущее время: 00:59. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru