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

Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 15, средняя оценка - 4.93
Vitekiss
1 / 1 / 0
Регистрация: 20.01.2013
Сообщений: 54
20.01.2013, 15:36     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #1
Задав двумерный массив вещественных данных (матрицу А), реализовать его обработку, как указано в варианте. Исходные данные задать самостоятельно, учитывая специфику задачи.
В программе должны быть предусмотрены функции ввода-вывода элементов массиваА и его обработки.

Вариант
Задана квадратная матрица A размером N x N (N<=10), состоящая из действительных элементов.

Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.01.2013, 15:36     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое
Посмотрите здесь:

Дан двумерный массив n*m Найти среднее арифметическое S его элементов и заменить этим числом элементы второй строки C++
Сформировать вектор из наименьших значений элементов строк данной матрицы C++
C++ Двумерный массив среднее арифметическое элементов и сумм строк,столбцов
Двумерный массив. Найти среднее арифметическое элементов, которые делятся на 4 или на 3 без остатка C++
Заполнить двумерный массив Е (5*3) с клавиатуры. Найти среднее арифметическое всех элементов массива. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Sergey_B
163 / 163 / 14
Регистрация: 08.01.2013
Сообщений: 335
20.01.2013, 17:27     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #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
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
using namespace std;
 
void main()
{
    setlocale(LC_ALL, "Russian");
 
    void ShowMatr(int n, int **a); //вывод матрицы на экран
    int* MinValue(int n, int **a); //мин. знач. в строке
    void ShowMas(int n, int *a);//вывод массива на экран
    int mSize = 0; //размерность матрицы
    
    cout<<"Введите размерность матрицы:\n";
    cin>>mSize;
      
    cout<<"Заполните матрицу...\n";
    // заполнение матрицы
        int **A = new int* [mSize]; //матрица
        for (int i=0;i<mSize;i++)
        {
            A=new int[mSize];
            for (int j=0;j<mSize;j++)
            {
                cin>>A[j];  //если заполнять случайным образом, то так: A[j] = rand(); + надо заголовочный файл подключить
            }
        }
 
        cout<<"\n Введенная матрица: \n";
        ShowMatr(mSize, A);
 
//поиск минимальных элементов в строках
        int* B = new int[mSize];
        B=MinValue(mSize, A);
        cout<<"\n Минимальные элементы строк матрицы: \n";
        ShowMas(mSize, B);
 
}//main
 
 // ф-ция вывода матриц
    void ShowMatr(int n, int **a)
    {
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<n;j++)
                cout<<setw(5)<<*(*(a+i)+j)<<ends;
            cout<<endl;
        }
    }
 // ф-ция вывода массивов
    void ShowMas(int n, int *a)
    {
        for(int i=0;i<n;i++)
        {           
            cout<<a<<" ";
        }
        cout<<endl;
    }
 
// ф-ция поиска минимальных значений в строках (формирует массив из мин. элементов)
    int* MinValue(int n, int **a)
    {
        int* mas = new int[n]; //сюда записываются значения мин. эл. строк
        int min;
 
        
        for (int i=0; i<n; i++)
        {
            min=a[i][0];
            for (int j=0; j<n; j++)
            {
                if (a[i]<min)
                {
                    min=a[i];
                }
            }
            
            mas[i] = min;
        }
        
        return mas;
    }
Добавлено через 7 минут
Поправлюсь, в функции MinValue, вместо:
C++
1
2
3
4
 if (a[i]<min)
                {
                    min=a[i];
                }
нужно:
C++
1
2
3
4
 if (a[j]<min)
                {
                    min=a[j];
                }
В коде могут быть недочеты, переделывал в блокноте из своей старой лабы
Vitekiss
1 / 1 / 0
Регистрация: 20.01.2013
Сообщений: 54
20.01.2013, 17:29  [ТС]     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #3
выбивает кучу ошибок
Sergey_B
163 / 163 / 14
Регистрация: 08.01.2013
Сообщений: 335
20.01.2013, 17:30     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #4
а заголовочные файлы подключили?
C++
1
2
3
4
#include <iostream>
#include <conio.h>
#include <iomanip>
#include <stdio.h>
А вот код из которого я все переделывал:
Кликните здесь для просмотра всего текста
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
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
#include <iostream>
#include <conio.h>
#include <iomanip>
#include <stdio.h>
#include <fstream>
 
 
 
using namespace std;
 
void main()
{
    setlocale(LC_ALL, "Russian");
 
    void ShowMatr(int n,int m, int **a); //вывод матрицы на экран
    int* MinValue(int n, int m, int **a); //мин. знач. в столбце
    void ShowMas(int n, int *a);//вывод массива на экран
    void PairValues();//создание массива пар и запись его в файл
    void MatrInFile(int n, int m, int **a);//запись матрицы в файл
 
    int mSizeX1, mSizeY1; //размерность первой матрицы
    int mSizeX2, mSizeY2; //размерность второй матрицы
 
 
            cout<<"Введите размерность первой матрицы:\n";
        cout<<"Введите количество строк:\n";
        cin>>mSizeX1;
        cout<<"Введите количество столбцов:\n";
        cin>>mSizeY1;
        cout<<"Заполните матрицу...\n";
           // заполнение первой матрицы
        int **A = new int* [mSizeX1]; //первая матрица
        for (int i=0; i<mSizeX1;i++)
        {
            A=new int[mSizeY1];
            for (int j=0;j<mSizeY1;j++)
            {
                cin>>A[j];  //если заполнять случайным образом, то так: A[j] = rand();
            }
        }
        
 
        cout<<"Введите размерность второй матрицы:\n";
        cout<<"Введите количество строк:\n";
        cin>>mSizeX2;
        cout<<"Введите количество столбцов:\n";
        cin>>mSizeY2;
        // заполнение второй матрицы
        cout<<"Заполните матрицу...\n";
        int **Q = new int* [mSizeX2]; //вторая матрица
        for (int i=0; i<mSizeX2;i++)
        {
            Q=new int[mSizeY2];
            for (int j=0;j<mSizeY2;j++)
            {
                 cin>>Q[j]; //если заполнять случайным образом, то так: Q[j] = rand();
            }
        }
        
 
        cout<<"\n Первая матрица: \n";
        ShowMatr(mSizeX1,mSizeY1,A);
        cout<<"\n Вторая матрица: \n";
        ShowMatr(mSizeX2,mSizeY2,Q);
 
 
        //поиск минимальных элементов в столбцах
        int* B = new int[mSizeY1];
        B=MinValue(mSizeX1,mSizeY1,A);
        cout<<"\n Минимальные элементы столбцов первой матрицы: \n";
        ShowMas(mSizeY1, B);
 
        int* R = new int[mSizeY2];
        R=MinValue(mSizeX2,mSizeY2,Q);
        cout<<"\n Минимальные элементы столбцов второй матрицы: \n";
        ShowMas(mSizeY2, R);
    
 
        //"Случайным образом создать таблицу пар целочисленных значений и записать её в текстовый файл"
        PairValues();
        
 
}
 
 
    // ф-ция вывода матриц
    void ShowMatr(int n, int m, int **a)
    {
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<m;j++)
                cout<<setw(5)<<*(*(a+i)+j)<<ends;
            cout<<endl;
        }
    }
 
 
    // ф-ция вывода массивов
    void ShowMas(int n, int *a)
    {
        for(int i=0;i<n;i++)
        {           
            cout<<a<<" ";
        }
        cout<<endl;
    }
 
 
     // ф-ция поиска минимальных значений в столбцах
    int* MinValue(int n, int m, int **a)
    {
        int* mas = new int[m]; //сюда записываются значения мин. эл. столбцов
        int min;
 
        
        for (int j=0; j<m; j++)
        {
            min=a[0][j];
            for (int i=0; i<n; i++)
            {
                if (a[j]<min)
                {
                    min=a[j];
                }
            }
            
            mas[j] = min;
        }
        
        return mas;
    }
 
 
    //ф-ция записи матрицы в файл
    void MatrInFile(int n, int m, int **a)
    {
        FILE* file = fopen("matrix.txt", "w+b");
        for (int i=0; i<n; i++)
        {
            for (int j=0; j<m; j++)
            {
                fprintf(file,"%4d", a[j]);
            }
            fprintf(file,"\n");
 
        }
        fclose(file);
 
    }
 
 
    // ф-ция создания массива пар и записи его в файл
    void PairValues()
    {
        int n;
        cout<<"Введите количество строк:\n";
        cin>>n;
        int **PairMatr = new int* [n]; 
        for (int i=0; i<n;i++)
        {
            PairMatr=new int[2];
            for (int j=0;j<2;j++)
            {
                PairMatr[j] = rand()%10;
            }
        }
        cout<<"Созданная матрица: \n";
        ShowMatr(n,2,PairMatr);
 
        //запись в файл
        MatrInFile(n,2,PairMatr);
 
        //чтение из файла
        int **temp = new int* [n]; 
        fstream fs;
        fs.open("matrix.txt", ios::in);
        
        for (int i=0; i<n; i++)
        {
            temp = new int[2];
            for (int j=0; j<2; j++)
            {               
                    fs>>temp[j];
            
            }
        }
        fs.close();
        cout<<"Матрица считанная из файла:\n";
        ShowMatr(n, 2,temp);
 
        /*Считать из файла пары значений и в тех из них, 
        где X является точным квадратом Y или наоборот, 
        найти сумму значений X и Y. Результат записать в другой текстовый файл*/
        FILE *res = fopen("result.txt", "w+b");
        for (int i=0; i<n; i++)
        {
            if (temp[0]*temp[0]==temp[1] || temp[1]*temp[1]==temp[0])
            {
                fprintf(res,"%4d", temp[0]);
                fprintf(res,"%4d", temp[1]);
                fprintf(res,"%4d", temp[0]+temp[1]);
                fprintf(res,"\n");
                
            }
            
        }
        fclose(res);
    }
Vitekiss
1 / 1 / 0
Регистрация: 20.01.2013
Сообщений: 54
20.01.2013, 17:43  [ТС]     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #5
Да и там 30 ошибок
Sergey_B
163 / 163 / 14
Регистрация: 08.01.2013
Сообщений: 335
20.01.2013, 18:04     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #6
сейчас скачаю компилятор попробую сам собрать
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4920 / 2663 / 243
Регистрация: 29.11.2010
Сообщений: 7,405
20.01.2013, 18:16     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #7
Допустим, есть std::vector<int> v;
при выводе строки матрицы на экран
v.push_back(*std::min_element(начало строки, конец строки) );
после std::accumulate(v.begin(), v.end(), 0.0) / v.size();
это и будет среднее арифмитическое
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.01.2013, 00:50     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое
Еще ссылки по теме:

C++ Дан двумерный массив m*n. Найти среднее арифметическое положительных элементов массива
C++ Сформировать вектор из сумм элементов строк матрицы и найти их среднее геомтрическое
C++ Создать двумерный массив размером NxM, Найти среднее арифметическое всех нечентых элементов с четными индексам

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

Или воспользуйтесь поиском по форуму:
Sergey_B
163 / 163 / 14
Регистрация: 08.01.2013
Сообщений: 335
21.01.2013, 00:50     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое #8
Vitekiss, а вы в какой среде работаете? И что за ошибки выбивает?

Добавлено через 6 часов 27 минут
Вот эт я натупил в вашей теме Прошу понять и простить на работе замучили (да и на С++ не писал больше года), вот исправляюсь:
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
#include <iostream>
#include <conio.h>
#include <locale.h>
#include <iomanip>
#include <vector>
 
 
using namespace std;
 
void main()
{
    setlocale(LC_ALL, "Russian");
 
    void ShowMatr(int n, int **a); //вывод матрицы на экран
    vector<int> MinValue(int n, int **a); //мин. знач. в строке
    void ShowVector(vector<int>&a_vec);//вывод массива на экран
    void VectorMean(vector<int> a_vec); //среднее арифметическое вектора
    int mSize = 0; //размерность матрицы
    
    cout<<"Введите размерность матрицы:\n";
    cin>>mSize;
      
    cout<<"Заполните матрицу...\n";
    // заполнение матрицы
        int **A = new int* [mSize]; //матрица
        for (int i=0;i<mSize;i++)
        {
            A[i]=new int[mSize];
            for (int j=0;j<mSize;j++)
            {
                cin>>A[i][j]; 
            }
        }
 
        cout<<"\n Введенная матрица: \n";
        ShowMatr(mSize, A);
 
        //поиск минимальных элементов в строках
        vector<int> myVector=MinValue(mSize, A);
        cout<<"\n Минимальные элементы строк матрицы: \n";
        ShowVector(myVector);
        VectorMean(myVector);
 
 
}
 
 // ф-ция вывода матриц
    void ShowMatr(int n, int **a)
    {
        for(int i=0;i<n;i++)
        {
            for(int j=0;j<n;j++)
                cout<<setw(5)<<*(*(a+i)+j)<<ends;
            cout<<endl;
        }
    }
 // ф-ция вывода вектора
   void ShowVector(vector<int>&a_vec)
{
        for (vector<int>::iterator it = a_vec.begin() ; it!=a_vec.end() ; ++it)
                cout<<setw(5)<<*it;
}
 
// ф-ция поиска минимальных значений в строках (формирует массив из мин. элементов)
    vector<int> MinValue(int n, int **a)
    {
        vector<int> myVector;  //вектор
        int min;
        //ищем минимальные эл-ты строках
        for (int i=0; i<n; i++)
        {
            min=a[i][0];
            for (int j=0; j<n; j++)
            {
                if (a[i][j]<min)
                {
                    min=a[i][j];
                }
            }            
            myVector.push_back(min); //помещаем найденный элемент в вонец вектора 
        }
        
        return myVector;
    }
 
    //ф-ция вычисления среднего ариф. вектора
    void VectorMean(vector<int> a_vec)
    {
        int sum=0;
        for (int i=0; i<(int)a_vec.size(); i++)
        {
            sum+=a_vec[i];
        }
        float mean = (float)sum/(float)a_vec.size();
        cout<<"\n Среднее арифметическое: "<<mean<<endl;
            
    }
правда код не красивый, зато работает
Вложения
Тип файла: rar lab1.rar (4.25 Мб, 18 просмотров)
Yandex
Объявления
21.01.2013, 00:50     Двумерный массив. Сформировать вектор из наименьших значений элементов строк и найти их среднее арифметическое
Ответ Создать тему
Опции темы

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