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

Поиск максимального из отрицательных - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Visual Studio 2010 C++ http://www.cyberforum.ru/cpp-beginners/thread206186.html
Помогите,пожалуйста с С++.Ввести длину, ширину и высоту комнаты. Подсчитать, сколько краски уйдет на покраску стен этой комнаты, если на 1м2 стены приходится 0.5 литра краски и 20% поверхности стен занимают окна и двери. #include<iostream> using namespace std; void main() { Заранее благодарен!!!!!!!!!!!!!
C++ Подсчитать количество пар букв Помогите, пожалуйста, с задачей! Во введенном слове подсчитать количество различных пар букв. Например, в слове babacabacd 5 различных пар букв, ba – 3 пары, ac – 2 пары.Язык C++. http://www.cyberforum.ru/cpp-beginners/thread206181.html
Индекс C++
Немного ламерский вопрос, но все же как в данной проге вывести вместо значения числа, его индекс в массиве? :) #include <iostream> #include <ctime> #if defined (_MSC_VER) && _MSC_VER <= 1200 #define for if (false) ; else for #endif int main () { const size_t ROW=4;
C++ Умножение матриц на число
Помогите написать программу , которая будет умножать число на матрицу , допустим x на A , все матрицы порядка 4х4
C++ Для каждого массива определить произведение средних арифметичеких значений элементов, расположенных ниже и выше главной диагонали http://www.cyberforum.ru/cpp-beginners/thread206166.html
Вот какая стоит передо мною задача: (программа на С++) "Даны вещественные массивы D, S. Для каждого массива определить произведение средних арифметичеких значений элементов, расположенных ниже и выше главной диагонали." Ниже, что я начал делать (ввел и вывел массивы) и застрял.
C++ Самая сложная зaдача по c++ в мире Здрасьте, мне препод по программированию задал написать задачу с функцией join , которая будет соединять две строки, которые надо будет ввести вручную. Нельзя использовать библиотеку стринг, только iostream. Спасайте подробнее

Показать сообщение отдельно
VladSharikov
22 / 22 / 1
Регистрация: 02.12.2010
Сообщений: 824
08.12.2010, 18:45  [ТС]     Поиск максимального из отрицательных
Напишите.
Нужна программа с функциями. Вот пример.
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
// Лабораторная работа 7, Задание 1.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
 
 
//прототипы фукнций
void InMas(int *, int); //функция ввода двумерного массива с клавиатуры
void InMas_rand(int *, int); //функция ввода одномерного массива массива через rand();
void InMatr_rand(int *, int, int); //функция ввода двумерноо массива через rand();
void InMatr_hand(int *, int, int); //функция ввода двумерного массива двумерного массива с клавиатуры
void OutMas(int *, int); //вывод массива
void OutMatr(int *, int, int); //вывод двумерного массива
int FindMaxMatrNegativ(int*, int, int); //поиск максимального из отрицательного элементов двумерного массива
int FindMaxMasNegativ(int*, int); //поиск максимального из отрицательного элементов одномерного массива
 
 
int main(void) {
 
    //объявление переменных и массивов
    const int column = 8, line = 8, size = 10;
    int matr[column][line], mas[size];
 
    //ввод массивов одномерного и двумерного(можно вводить с клавиатуры "_hand" и через rand(); "_rand"
    InMas_rand(mas, size);
    InMatr_rand(&matr[0][0], column, line);
 
    //вывод массивов одномерного и двумерного
    //printf("\t Old One-Dimensional Array: \n\n");
    OutMas(mas, size);
    //printf("\n\n\------ \n\t Old Two-Dimensional Array: \n\n");
    OutMatr(&matr[0][0], column, line);
    //printf("------\n");
 
    //поиск максимального из отрицательных чисел в обоих массивах
    int MaxMatrNegativ = FindMaxMatrNegativ(&matr[0][0], column, line);
    int MaxMasNegativ = FindMaxMasNegativ(mas, size);
 
    //ищем сумму максимальных отрицательных элементов
    int sum = MaxMasNegativ + MaxMatrNegativ;
 
    //вывод суммы на экран
    printf("SUM: %d", sum);
 
    return 0;
}
 
 
void InMas_rand(int *mas, int size) {
 
    srand(unsigned(time(NULL)));
    for(int i = 0; i < size; i ++) {
        mas[i] = rand() % 100 - 50;
    }
 
}
 
void InMas_hand(int *mas, int size) {
 
    for(int i = 0; i < size; i ++) {
        scanf_s("%d", &mas[i]);
    }
 
}
 
 
void InMatr_rand(int *matr, int column, int line) { 
 
    srand(unsigned(time(NULL)));
    for(int i = 0; i < line; i++) {
        for(int j = 0; j < column; j++) {
             matr[ i * line + j] = rand() % 99 - 49;
        }
    }
 
}
 
void InMatr_hand(int *matr, int column, int line) {
 
    for(int i = 0; i < line; i++) {
        for(int j = 0; j < column; j++) {
             scanf_s("%d", &matr[i * line + j]);
        }
    }
 
}
 
 
void OutMas(int *mas, int size) {
 
    for(int i = 0; i < size; i++) {
        printf("%4d ", mas[i]);
        if((i + 1) % 5 == 0) {
            printf("\n\n");
        }
    }
 
}
 
 
void OutMatr(int *matr, int column, int line) {
 
    for(int i = 0; i < line; i++) {
        for(int j = 0; j < column; j++) {
            printf("%3d ", matr[i * line + j]); 
            if( (j + 1)  % column == 0) {
                printf("\n\n"); 
            }
        }
    }
 
}
 
int FindMaxMatrNegativ(int *matr, int column, int line) {
 
    int result;
    for(int i = 0; i < line; i++) {
        for(int j = 0; j < column; j++) {
            if(matr[ i * line + j ] < 0) {
                result = matr[ i * line + j];
            }
        }
    }
 
    for(int i = 0; i < line; i++) {
        for(int j = 0; j < column; j++) {
            if(matr[ i * line + j ] < 0 && matr[ i * line + j ] > result) {
                result = matr[ i * line + j ];
            }
        } 
    }
    return result;
 
}
 
 
int FindMaxMasNegativ(int *mas, int size) {
 
    int result = 0;
    for(int i = 0; i < size; i++) {
        if(mas[i] < 0) {
            result = mas[i];
        }
    }
    
    for(int i = 0; i < size; i++) {
        if(mas[i] < 0 && mas[i] > result) {
            result = mas[i];
        }
    }
 
    return result;
 
}
Именно в таком виде.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru