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

Найти номер элемента, значение которого близко к среднему значению массива - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.67
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 17:10     Найти номер элемента, значение которого близко к среднему значению массива #1
не пойму, что не так....


C++ (Qt)
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
#include "stdafx.h"
 
#include <iostream>
#include <conio.h>
#include <clocale>
#include <math.h>
#include <cstdlib>
#include <memory.h>
 
using namespace std;
using std::cout;
using std::cin;
using std::endl;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russia");
    setlocale(LC_ALL, "rus");
    float *x;
    int n = 0;
    int menu = 0;
    float sum = 0; //sum - сумма всех элементов массива.
    float sred = 0; //sred - среднее значение всех элементов массива
    float max = sizeof(int);
    float min = sizeof(int);
    float m;//То самое число, которое нужно найти.
 
     
    do
    {
        cout << "\nПрограмма для нахождения номер, значение которого близко к среднему значению массива.\n\n";
        cout << "1. Задать случайный массив.\n";
        cout << "2. Самостоятельный ввод массива.\n";
        cout << "3. Показать массив.\n";
        cout << "4. Нахождение суммы масива.\n";
        cout << "5. Среднее значение массива.\n";
        cout << "6. Показать тот номер, который ближе всего к среднему значению.\n";
        cout << "____________________________\n";
        cout << "0. Выход.\n";
 
    cin >> menu;
    switch(menu){
        case 1: cout << "Массив, задался случайно. \n";
            n = 10;
            x = new float[n];
            for(int i = 0; i < n; i++)
               x[i] = rand();
            cout << "\n\n";
            break;
        case 2: cout << "Ввод массива самостоятельно: \n";
            cout << "Введите n\n";
            cin >> n;
            x = new float[n];
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = ";
                   cin >> x[i];
                }
            break;
        case 3: cout << "Показ массива: \n\t";
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = " << x[i] << endl;
                   cout << "\t";
                }
            break;
        case 4: for(int i = 0; i < n; i++)
                   sum = sum + x[i];
                      cout << "\n" << "Сумма всех элементов: " << sum << endl;
                      cout << "\n\n";
            break;
        case 5: sred = sum / n;
                   cout << "Среднее значение равно: \n" << sred << endl;
                   cout << "\n\n";
 
            break;
        case 6:
            for(int i = 0; i < n; ++i){
                if(x[i] > max){
                    max = x[i];
                }
 
            }
            for(int i = 0; i < n; ++i){
                if(fabs (x[i] - sred) < min){
                    min = fabs (x[i] - sred);
                    m = min;
                }
            }
            break;
        case 0:
            break;
        default: cout << "Вы ввели неверный пункт меню!\n\n\n";
    }
    }while (menu != 0);
 
    delete []x;
    _getch();
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.10.2012, 17:10     Найти номер элемента, значение которого близко к среднему значению массива
Посмотрите здесь:

C++ Найти элемент массива, значение которого наиболее близко к какому-нибудь целому числу
C++ Найти номер элемента, значение которого наименее отклоняется от среднего значения
Найти номер элемента из массива А, с которого массив В начинается как подпоследовательность C++
Найти номер элемента из массива А, с которого массив В начинается как подпоследовательность C++
Вычислить номер элемента, значение которого близкое к среднему арифметическому всех элементов массива C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 17:14     Найти номер элемента, значение которого близко к среднему значению массива #2
Что не так?
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 17:20  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #3
ну когда запускаю, среднее знаение всё время = 0 и не находит номер элемента массива
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 17:32     Найти номер элемента, значение которого близко к среднему значению массива #4
Насчёт среднего, не знаю. У меня выводит не 0. А где вывод номера сделан?
Миниатюры
Найти номер элемента, значение которого близко к среднему значению массива  
247
0 / 0 / 0
Регистрация: 25.09.2012
Сообщений: 5
01.10.2012, 17:44     Найти номер элемента, значение которого близко к среднему значению массива #5
В вашей программе перед подсчетом среднего значения всегда надо запускать пункт 4. Нахождение суммы массива. Чтобы запускать можно было в любом порядке просто добавьте подсчет суммы в 1 и 2 пункты.
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 17:47  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #6
по описанию, я должен это сделать отдельно, так что нельзя добавить, получается, чтобы команда работала коректно, надо сначала нажать 1 или 2, потом обязательно 4 и 5, так?
247
0 / 0 / 0
Регистрация: 25.09.2012
Сообщений: 5
01.10.2012, 17:49     Найти номер элемента, значение которого близко к среднему значению массива #7
Цитата Сообщение от dmmax Посмотреть сообщение
чтобы команда работала коректно, надо сначала нажать 1 или 2, потом обязательно 4 и 5, так?
да, именно так
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 17:49  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #8
Так, со средним значением разобрались, помогите теперь пожалуйста, как сделать, чтобы показывался тот самый номер, который ближе всего к среднему значению.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 18:09     Найти номер элемента, значение которого близко к среднему значению массива #9
Если по быстрому, то так работает:
Код
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
#include "stdafx.h"
 
#include <iostream>
#include <conio.h>
#include <clocale>
#include <math.h>
#include <cstdlib>
#include <memory.h>
#include <ctime>
 
using namespace std;
using std::cout;
using std::cin;
using std::endl;
 
int main(int argc, char* argv[])
{
    setlocale(LC_ALL, "Russia");
    setlocale(LC_ALL, "rus");
    float *x;
    int n = 0;
    int menu = 0;
    float sum = 0; //sum - сумма всех элементов массива.
    float sred = 0; //sred - среднее значение всех элементов массива
    float max = sizeof(int);
    float min = sizeof(int);
    float m;//То самое число, которое нужно найти.
    srand(time(0));
 
     
    do
    {
        cout << "\nПрограмма для нахождения номер, значение которого близко к среднему значению массива.\n\n";
        cout << "1. Задать случайный массив.\n";
        cout << "2. Самостоятельный ввод массива.\n";
        cout << "3. Показать массив.\n";
        cout << "4. Нахождение суммы масива.\n";
        cout << "5. Среднее значение массива.\n";
        cout << "6. Показать тот номер, который ближе всего к среднему значению.\n";
        cout << "____________________________\n";
        cout << "0. Выход.\n";
 
    cin >> menu;
    switch(menu){
        case 1: cout << "Массив, задался случайно. \n";
            n = 10;
            x = new float[n];
            for(int i = 0; i < n; i++)
               x[i] = rand();
            cout << "\n\n";
            break;
        case 2: cout << "Ввод массива самостоятельно: \n";
            cout << "Введите n\n";
            cin >> n;
            x = new float[n];
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = ";
                   cin >> x[i];
                }
            break;
        case 3: cout << "Показ массива: \n\t";
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = " << x[i] << endl;
                   cout << "\t";
                }
            break;
        case 4: for(int i = 0; i < n; i++)
                   sum = sum + x[i];
                      cout << "\n" << "Сумма всех элементов: " << sum << endl;
                      cout << "\n\n";
            break;
        case 5: sred = sum / n;
                   cout << "Среднее значение равно: \n" << sred << endl;
                   cout << "\n\n";
 
            break;
        
        case 6:
        
            for(int i = 0; i < n; i++) 
                if(x[i] > max) max = x[i];
            
            
            min = fabs (x[0] - sred);
            for(int i = 1; i < n; ++i)
            {
                if(fabs (x[i] - sred) > min) continue;
                else min = fabs (x[i] - sred);
                m = x[i];
            }
            cout << "m = " << m << endl;
            break;
        
        case 0:
            break;
        
        default: cout << "Вы ввели неверный пункт меню!\n\n\n";
    }
    }while (menu != 0);
 
    delete []x;
    
    _getch();
    return 0;
}
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 18:24  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #10
alsav22, огромное спасибо, теперь бы пояснили, что вы сделали, было бы вообще супер я с массивами только третий день, поэтому не сильно дружу...разобраться трудно.

Добавлено через 9 минут
alsav22, о нет, у вас ошибка, там нужно значение массива , а номер массива, значение массива, та я и сам мог сделать я не понимаю как номер массива узнать.
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 18:30     Найти номер элемента, значение которого близко к среднему значению массива #11
C++
1
2
3
4
5
6
7
8
min = fabs (x[0] - sred); // в min разница между первым элементом массива и средним значением
            for(int i = 1; i < n; ++i) // перебор массива и нахождение элемента с разницей меньше, чем min
            {
                if(fabs (x[i] - sred) > min) continue; // если разница больше, то переход к следующему  элементу
                else min = fabs (x[i] - sred); // если разница меньше, то сохраняем новую разницу
                m = x[i]; // и сохраняем значение этого элемента
            }
            cout << "m = " << m << endl; // вывод найденного элемента
Наверное, можно сделать более рационально, но нет времени.

Добавлено через 49 секунд
Цитата Сообщение от dmmax Посмотреть сообщение
alsav22, о нет, у вас ошибка, там нужно значение массива , а номер массива, значение массива, та я и сам мог сделать я не понимаю как номер массива узнать.
Проблема i вывести?
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 18:35  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #12
alsav22, проблема вывести i, где находится то значение, которое ближе всего к среднему значению =)
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 18:38     Найти номер элемента, значение которого близко к среднему значению массива #13
Код
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
#include "stdafx.h"
 
#include <iostream>
#include <conio.h>
#include <clocale>
#include <math.h>
#include <cstdlib>
#include <memory.h>
#include <ctime>
 
using namespace std;
using std::cout;
using std::cin;
using std::endl;
 
int main(int argc, char* argv[])
{
    setlocale(LC_ALL, "Russia");
    setlocale(LC_ALL, "rus");
    float *x;
    int n = 0;
    int menu = 0;
    float sum = 0; //sum - сумма всех элементов массива.
    float sred = 0; //sred - среднее значение всех элементов массива
    float max = sizeof(int);
    float min = sizeof(int);
    float m;//То самое число, которое нужно найти.
    srand(time(0));
 
     
    do
    {
        cout << "\nПрограмма для нахождения номер, значение которого близко к среднему значению массива.\n\n";
        cout << "1. Задать случайный массив.\n";
        cout << "2. Самостоятельный ввод массива.\n";
        cout << "3. Показать массив.\n";
        cout << "4. Нахождение суммы масива.\n";
        cout << "5. Среднее значение массива.\n";
        cout << "6. Показать тот номер, который ближе всего к среднему значению.\n";
        cout << "____________________________\n";
        cout << "0. Выход.\n";
 
    cin >> menu;
    switch(menu){
        case 1: cout << "Массив, задался случайно. \n";
            n = 10;
            x = new float[n];
            for(int i = 0; i < n; i++)
               x[i] = rand();
            cout << "\n\n";
            break;
        case 2: cout << "Ввод массива самостоятельно: \n";
            cout << "Введите n\n";
            cin >> n;
            x = new float[n];
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = ";
                   cin >> x[i];
                }
            break;
        case 3: cout << "Показ массива: \n\t";
                for(int i = 0; i < n; i++){
                   cout << "x[" << i << "] = " << x[i] << endl;
                   cout << "\t";
                }
            break;
        case 4: for(int i = 0; i < n; i++)
                   sum = sum + x[i];
                      cout << "\n" << "Сумма всех элементов: " << sum << endl;
                      cout << "\n\n";
            break;
        case 5: sred = sum / n;
                   cout << "Среднее значение равно: \n" << sred << endl;
                   cout << "\n\n";
 
            break;
        
        case 6:
        {
        
            for(int i = 0; i < n; i++) 
                if(x[i] > max) max = x[i];
            
            
            int ind = 0;
            min = fabs (x[ind] - sred);
            for(int i = 0; i < n; ++i)
            {
                if(fabs (x[i] - sred) > min) continue;
                else min = fabs (x[i] - sred);
                ind = i; //сохраняем индекс элемента
            }
            m = x[ind]; // сохраняем элемент с найденым индексом
            cout << "ind = " << ind << endl << "m = " << m << endl;
            break;
        }
        
        case 0:
            break;
        
        default: cout << "Вы ввели неверный пункт меню!\n\n\n";
    }
    }while (menu != 0);
 
    delete []x;
    
    _getch();
    return 0;
}
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 18:44  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #14
alsav22, Большое спасибо
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
01.10.2012, 18:45     Найти номер элемента, значение которого близко к среднему значению массива #15
Я там сейчас исправил кое-что, посмотрите.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
01.10.2012, 19:19     Найти номер элемента, значение которого близко к среднему значению массива
Еще ссылки по теме:

Найти элемент массива, наиболее близкий к среднему значению всех элементов массива C++
C++ Найти номер элемента массива, ближайшего к среднему арифметическому его значений
Определить номер элемента массива значение которого равно заданному числу C++

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

Или воспользуйтесь поиском по форуму:
dmmax
 Аватар для dmmax
0 / 0 / 0
Регистрация: 24.09.2012
Сообщений: 81
01.10.2012, 19:19  [ТС]     Найти номер элемента, значение которого близко к среднему значению массива #16
alsav22, Посмотрел, это я уже сам учёл =)
Yandex
Объявления
01.10.2012, 19:19     Найти номер элемента, значение которого близко к среднему значению массива
Ответ Создать тему
Опции темы

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