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

Передача массива в функцию. Не могу понять что не так - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ operator+ overload http://www.cyberforum.ru/cpp-beginners/thread1090741.html
#include <iostream> class point { private: int x; int y; public:
C++ Доступ к элементу структуры, массив которых хранится в vector Как получить доступ к элементу структуры, если несколько структур хранится в vector? Я прохожу по вектору через итератор. vector<trade>::iterator it; for(it=first.begin();it!=first.end();it++) { } В цикле я хочу каждый раз записывать все элементы структуры trade в строку и выводить на экран. http://www.cyberforum.ru/cpp-beginners/thread1090722.html
C++ Создание собственной функции
Даны натуральные числа m, n и целые числа A1,..., An; B1,..., Bm;C1,..., C10. Создать собственную функцию для расчёта минимума из массива чисел MIN(L). Вычислить значение выражения, используя функцию MIN(L): L=min(B1,...,Bm)+min(C1,..., C10)/1+(max(A1,..., An) #include <iostream> #include <math.h> #include "stdafx.h" template<typename T> T massmin(int from, int to, T *m) { T ret = m;...
C++ Графический примитив
Написать программу, рисующую данную фигуру. p.s подскажите, есть ли какие-нибудь графические библиотеки для dev c++ ?
C++ Замена первого столбца на последний в массиве http://www.cyberforum.ru/cpp-beginners/thread1090682.html
Задание : поменять местами первого столбца массива на последний( размерность массива с клавы) Я чего-то начал делать, но получилась галиматья: #include "stdafx.h" #include <iostream> #include <time.h> using namespace std; int main() { int j, k, N, M; srand(time(NULL));
C++ Сложность в разработке класса содержащий список объектов Доброе время суток! Ув. форумчани, c ООП знакома поверхностно поэтому не судите строго, имеется следующая задача: Используя понятие множественного наследования, разработайте класс "Окружность, вписаная в квадрат". Создайте класс, хранящий список таких объектов, переопределив + и - для добавления и удаления объектов, а также операцию индексации. Продемонстрируйте работу со списком в функции... подробнее

Показать сообщение отдельно
Влад1986
1 / 1 / 0
Регистрация: 01.02.2014
Сообщений: 8
07.02.2014, 20:12  [ТС]     Передача массива в функцию. Не могу понять что не так
Вот что у меня получилось. Может кому-нибудь пригодится.

СТАТИЧЕСКИЙ МАССИВ:
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include<climits>
using namespace std;
const int n = 3;
const int m = 3;
void massiv(int a[][m]) {
  for(int i = 0; i < m; i++) {
     for(int j = 0; j < n; j++) {
           cout << a[i][j] <<' ';
     }
   cout << endl;
}
}
int SearchMaxColumn(int a[][m],int n,int m); // функция поиска максимального элемента
int SearchMinColumn(int a[][m],int n,int m); // функция поиска минимального элемента
int Average(int a[][m],int n,int m,int value); // Функция поиска среднего арифметического строки массива, возвращает количество строк, среднее арифметическое которых меньше value
void ExchangeColumn(int a[][m],int n,int p,int q); //Функция меняет столбцы местами
void PrintMatrix(int a[][m],int m,int n); // Функция вывода матрицы
int main() {
    int a[n][m]={3,7,8,9,1,4,5,10,6};
    std::cout<<"Dannyj massiv: \n";
    massiv(a);
    int p, q;
    q=SearchMaxColumn(a,n,m);
    p=SearchMinColumn(a,n,m);
    cout<<'\n';
    ExchangeColumn(a,n,p,q);
    PrintMatrix(a,n,m);
    std::cout<<"Enter value:";
    int value;
    std::cin>>value;
    double Answer=Average(a,n,m,value);
    std::cout<<"Answer: "<<Answer<<std::endl;
    return 0;
}
int Average(int a[][m],int n,int m,int value)
{
    double sum=0,k=0;
    for (int i=0;i<n;++i)
    {
    for(int j=0;j<m;++j)
    {
        sum+=a[i][j];
    }
    sum=sum/m;
    if (sum<value)
        k++;
    }
    return k;
}
int SearchMaxColumn(int a[][m],int n,int m)
{
    int max=INT_MIN,jmax;
    for (int i=0;i<n;++i)
    {
    for (int j=0;j<m;++j)
    if (max<a[i][j])
    {
    max=a[i][j];
    jmax=j;
    }
    }
    std::cout<<"Max element: "<<max<<std::endl;
    return jmax;
}
int SearchMinColumn(int a[][m],int n,int m)
{
    int min=INT_MAX,jmin;
    for (int i=0;i<n;++i)
    {
    for (int j=0;j<m;++j)
    if (min>a[i][j])
    {
    min=a[i][j];
    jmin=j;
    }
    }
    std::cout<<"Min element: "<<min<<std::endl;
    return jmin;
}
void ExchangeColumn(int a[][m],int n,int p,int q)
{
    int s;
    for (int i=0;i<n;++i)
    {
    s=a[i][p];
    a[i][p]=a[i][q];
    a[i][q]=s;
    }
}
void PrintMatrix(int a[][m],int n,int m)
{
    for (int i=0;i<n;++i)
    {
    for(int j=0;j<m;++j)
    {
    std::cout<<a[i][j]<<" ";
    }
    std::cout<<std::endl;
    }
}
ДИНАМИЧЕСКИЙ МАССИВ:
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include<climits>
using namespace std;
int SearchMaxColumn(int **a,int n,int m); // функция поиска максимального элемента
int SearchMinColumn(int **a,int n,int m); // функция поиска минимального элемента
int Average(int **a,int n,int m,int value); // Функция поиска среднего арифметического строки массива, возвращает количество строк, среднее арифметическое которх меньше value
void ExchangeColumn(int **a,int n,int p,int q); //Функция меняет столбцы местами
void PrintMatrix(int **a,int m,int n); // Функция вывода матрицы
int main() {
    int n, m, p, q;
    cout << "Vvedite kol-vo strok:\n";
    std::cin >> n;
    cout << "Vvedite kol-vo stolbcov:\n";
    std::cin >> m;
    int **a = new int* [n];
        for (int i = 0; i<n;++i) a[i] = new int [m];
        cout << "Vvedite massiv:\n";
        for (int i=0; i<n; i++)
            for (int j=0; j<m; j++) cin>> a[i][j];
        cout << "Poluchennyi massiv:\n";
        for (int i=0; i<n; i++){
            for (int j=0; j<m; j++) cout<< a[i][j]<<"  ";
            std::cout<<std::endl;
        }
    q=SearchMaxColumn(a,n,m);
    p=SearchMinColumn(a,n,m);
    cout<<'\n';
    ExchangeColumn(a,n,p,q);
    PrintMatrix(a,n,m);
    std::cout<<"Enter value:";
    int value;
    std::cin>>value;
    double Answer=Average(a,n,m,value);
    std::cout<<"Answer: "<<Answer<<std::endl;
    return 0;
}
int Average(int **a,int n,int m,int value)
{
    int sum=0,k=0;
    for (int i=0;i<n;++i)
    {
    for(int j=0;j<m;++j)
    {
        sum+=a[i][j];
    }
    sum=sum/m;
    if (sum<value)
        k++;
    }
    return k;
}
int SearchMaxColumn(int **a,int n,int m)
{
    int max=INT_MIN,jmax;
    for (int i=0;i<n;++i)
    {
    for (int j=0;j<m;++j)
    if (max<a[i][j])
    {
    max=a[i][j];
    jmax=j;
    }
    }
    std::cout<<"Max element: "<<max<<std::endl;
    return jmax;
}
int SearchMinColumn(int **a,int n,int m)
{
    int min=INT_MAX,jmin;
    for (int i=0;i<n;++i)
    {
    for (int j=0;j<m;++j)
    if (min>a[i][j])
    {
    min=a[i][j];
    jmin=j;
    }
    }
    std::cout<<"Min element: "<<min<<std::endl;
    return jmin;
}
void ExchangeColumn(int **a,int n,int p,int q)
{
    int s;
    for (int i=0;i<n;++i)
    {
    s=a[i][p];
    a[i][p]=a[i][q];
    a[i][q]=s;
    }
}
void PrintMatrix(int **a,int n,int m)
{
    for (int i=0;i<n;++i)
    {
    for(int j=0;j<m;++j)
    {
    std::cout<<a[i][j]<<" ";
    }
    std::cout<<std::endl;
    }
}
 
Текущее время: 15:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru