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

Задача на функции - C++

Восстановить пароль Регистрация
 
Devil7
0 / 0 / 0
Регистрация: 05.10.2011
Сообщений: 97
08.12.2011, 23:25     Задача на функции #1
Найти сумму минимальных и разницу максимальных элементов матриц Y(9*12) и Q(5*10).
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.12.2011, 23:25     Задача на функции
Посмотрите здесь:

C++ Задача на функции!!!!!
Задача в С++. Функции и массивы. C++
Задача. Табулирование функции. C++
C++ Массивы и функции. Задача по С++
C++ Задача на функции
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
amor1k
Студент
 Аватар для amor1k
147 / 147 / 24
Регистрация: 18.01.2011
Сообщений: 469
08.12.2011, 23:49     Задача на функции #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
#include <iostream>
#include <ctime>
using namespace std;
 
int main()
{
    srand(time(NULL));
    int y[9][12], q[5][10];
    for(int i = 0; i < 9; i++)
        for(int j = 0; j < 12; j++)
            y[i][j] = rand() % 20;
 
    for(int i = 0; i < 5; i++)
        for(int j = 0; j < 10; j++)
            q[i][j] = rand() % 17;
 
    int min = y[0][0], max = y[0][0];
    for(int i = 0; i < 9; i++)
        for(int j = 0; j < 12; j++)
        {
            if(y[i][j] < min)
                min = y[i][j];
            if(y[i][j] > max)
                max = y[i][j];
        }
    int sum = min;
    min = q[0][0];
    int max2 = q[0][0];
    for(int i = 0; i < 5; i++)
        for(int j = 0; j < 10; j++)
        {
            if(q[i][j] < min)
                min = q[i][j];
            if(q[i][j] > max2)
                max2 = q[i][j];
        }
        cout << min;
    sum += min;
    int res = 0;
    if(max > max2)
        res = max - max2;
    else if(max < max2)
        res = max2 - max;
    else if(max == max2)
        cout << "There is not a difference" << endl;
    cout << "Summa min = " << sum << ", Difference = " << res;
}
Devil7
0 / 0 / 0
Регистрация: 05.10.2011
Сообщений: 97
09.12.2011, 08:56  [ТС]     Задача на функции #3
Тут же нету функций.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
09.12.2011, 09:00     Задача на функции #4
Цитата Сообщение от Devil7 Посмотреть сообщение
Тут же нету функций.
Ну как минимум одна-то точно есть...
BRcr
09.12.2011, 09:23
  #5

Не по теме:

Цитата Сообщение от Devil7 Посмотреть сообщение
Тут же нету функций.
Как же так?! Нету функций - так не бывает!
Это мне один анекдотик напомнило...
Вот говорят: "Меня никто не любит. Любви не бывает."
А у меня машины нету - всё, б####, машин не бывает! ©

MBazarov
5 / 3 / 1
Регистрация: 08.12.2011
Сообщений: 15
09.12.2011, 11:20     Задача на функции #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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#include <cstdlib>
 
using namespace std;
 
 
 
 
int get_max(int* array, int length)
    {
        int max = array[0];
        for(int i = 0; i < length; i++)
                    if(array[i] > max) max = array[i];
        return max;
    
    }
int get_min(int* array, int length)
    {
        int min = array[0];
        for(int i = 0; i < length; i++)
                    if(array[i] > min) min = array[i];
        return min;
    
    }
 
 
 
int main()
{
        
        srand(time(NULL));
        int y[9][12], q[5][10];
        
        // Заполнение массивов случайными значениями
        for(int i = 0; i < 9; i++)
                for(int j = 0; j < 12; j++)
                        y[i][j] = rand() % 20;
 
        for(int i = 0; i < 5; i++)
                for(int j = 0; j < 10; j++)
                        q[i][j] = rand() % 17;
        // Подсчет сумм
        int summin = get_min(*y,9*12)+get_min(*q,5*10);
        int difmax = abs (get_max(*y,9*12)+get_max(*q,5*10) );
        cout << "Summa min = " << summin << ", Difference = " << difmax;
     
}
Смотри внимательно если непонятно спрашивай, вкратце: передать в функцию двумерный массив задача сложная для понимания, поэтому в функцию передается указатель на начало массива и его длинна, потом в цикле пробегается по цепочке и находится максимум.

2 easybudda : вы действительно здесь за тем чтоб постебаться? или невнимательно прочитать условие задачи и запостить неверное решение? ваш статус, мне кажется вас к некоторой модели поведения обязывает, и оно всяко исключает стеб.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.12.2011, 22:08     Задача на функции
Еще ссылки по теме:

Задача на функции C++
Задача по теме функции C++
C++ Задача на функции

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

Или воспользуйтесь поиском по форуму:
Devil7
0 / 0 / 0
Регистрация: 05.10.2011
Сообщений: 97
09.12.2011, 22:08  [ТС]     Задача на функции #7
MBazarov, Вот это я понимаю, спасибо наиогромное! Очень помог. А то щас функции только что начались на лекции, а лабу нужно уже сдавать. Благодарю!

Добавлено через 52 минуты
Вот подкорректированная работающая задача со всеми функциями. Как я рад!
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
void input(int *array, int lenght);
void output(int *array, int lenght, int k);
int get_max(int *array, int length);
int get_min(int *array, int length);
 
 
int main(void)
{
    int y[9][12], q[5][10]; 
    srand(time(NULL));
    printf("Array:\n");
    input(&(y[0][0]), 9*12); 
    output(&y[0][0], 9, 12);
    printf("Array:\n");
    input(&q[0][0], 5*10); 
    output(&q[0][0], 5, 10);
    //Подсчет суммы, разности и отношение суммы min к разности max элементов массива
    int summin = get_min(*y,9*12)+get_min(*q,5*10);
    int difmax = get_max(*y,9*12)-get_max(*q,5*10);
        if(summin==0||difmax==0)
            printf("\n\n Error! summin or difmax raven 0\n");
        else if (summin!=0&&difmax!=0)
            printf("\n\n Summin= %d\t Diferencemax= %d\t Sootnoh= %f\n",summin,difmax,((float)summin)/((float)difmax)); 
            
    return 0;
}
//Ввод массива
void input(int *array, int lenght)
{
    int i;
    for(i=0;i<lenght;i++)
        *(array+i) = rand()%100+10;
}
//Вывод массива
void output(int *array, int lenght, int k)
{
    int i, j;
    for(i=0;i<lenght;i++)
    {
        for(j=0;j<k;j++)
            printf("%4d", *(array+i*k+j));
        printf("\n");
    }
}
// Функция max элемента массива
int get_max(int* array, int length)
    {
        int max = array[0];
        for(int i = 0; i < length; i++)
                    if(array[i] > max) max = array[i];
        return max;
    
    }
//Функция min элемента массива
int get_min(int* array, int length)
    {
        int min = array[0];
        for(int i = 0; i < length; i++)
                    if(array[i] < min) min = array[i];
        return min;
    
    }
Yandex
Объявления
09.12.2011, 22:08     Задача на функции
Ответ Создать тему
Опции темы

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