Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
#1

Найти минимальный элемент из максимальных элементов строк двухмерного массива целых чисел - C++

11.12.2010, 10:23. Просмотров 1391. Ответов 12
Метки нет (Все метки)


http://www.cyberforum.ru/cpp-beginners/thread140923.html
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.12.2010, 10:23
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Найти минимальный элемент из максимальных элементов строк двухмерного массива целых чисел (C++):

Дан массив целых чисел. Найти В этом массиве минимальный элемент т и максимальный элемент м. Вывести сумму элементов от минимального до максимального
Дан массив целых чисел. Найти В этом массиве минимальный элемент т и...

Дан массив а, состоящий из n целых чисел (n < = 100). Найти количество максимальных элементов массива
Дан массив а, состоящий из n целых чисел (n &lt; = 100). Найти количество...

Дан массив а, состоящий из n целых чисел (n < = 100). Найти количество максимальных элементов массива
не могу найти ошибку #include &lt;iostream.h&gt; #include &lt;conio.h &gt; void ...

В каждой строке двухмерного массива определить наибольший элемент и подсчитать сумму этих максимальных элементов
В каждой строке двухмерного массива определить наибольший элемент и подсчитать...

Пользуясь указателем на массив целых чисел, найти минимальный и максимальный элемент массива
Пользуясь указателем на массив целых чисел, найти минимальный и максимальный...

12
fasked
Эксперт С++
4976 / 2556 / 241
Регистрация: 07.10.2009
Сообщений: 4,311
Записей в блоге: 1
11.12.2010, 10:41 #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
#include <stdio.h>
#include <stdlib.h>
 
#define ROWS 5
#define COLS 5
 
int main()
{
        int i = 0;
        int j = 0;
        int max = 0;
        int min = 0;
        int ymax = 0;
        int xmax = 0;
        int xmin = 0;
        int ymin = 0;
        int matrix[ROWS][COLS];
 
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j)
                        matrix[i][j] = rand() % 100;
        }
 
        min = matrix[0][0];
        for(i = 0; i < ROWS; ++i) {
                max = matrix[i][0];
                for(j = 0; j < COLS; ++j) {
                        if(max < matrix[i][j]) {
                                max = matrix[i][j];
                                xmax = j;
                                ymax = i;
                        }
                }
 
                if(min > max) {
                        min = max;
                        xmin = xmax;
                        ymin = ymax;
                }
        }
 
        for(i = 0; i < ROWS; ++i) {
                for(j = 0; j < COLS; ++j)
                        printf("%2d ", matrix[i][j]);
 
                printf("\n");
        }
 
        printf("min: %d, x: %d, y = %d\n", min, xmin, ymin);
        return 0;
}
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 11:32  [ТС] #3
Спасибо. Все правильно

Добавлено через 13 минут
Странно, правильно работает если rand() %50
0
MILAN
888 / 782 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 12:07 #4
Serhiy, а почему оно должно не работать? Вы просто меняете диапазон генерации случайных чисел!!!!
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 12:41  [ТС] #5
Щас еще раз проверю.

Добавлено через 12 минут
Вот что программа выводит
41 67 34 0
69 24 78 58
62 64 5 45
min: 41, x:0, y=0

Добавлено через 1 минуту
min: 64 а не 41!
0
MILAN
888 / 782 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 12:46 #6
Serhiy, все правильно. Индексация масивов начинается с 0. Первый елемент будет с индексом х=0, у=0, у вас первый - мимимальный.

И еще, добавте строку

C
1
srand((unsigned)time(NULL))
и библиотеку

C
1
#include <time.h>
и запустите програму несколько раз
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 12:55  [ТС] #7
Добавил. Числа теперь генерируются разные. Я уже пол дня сижу тут и почти ничего с этой проги не понимаю
0
MILAN
888 / 782 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 13:02 #8
Serhiy, програма верно работает. Что вас смущает?
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 13:22  [ТС] #9
41 не максимальный элемент 0-й строки матрицы, то как он может быть минимальным если минимальный нужно найти с максимальных элементов строк матрицы?????????

Добавлено через 13 минут
41 67 34 0
69 24 78 58
62 64 5 45
В 0-й стороке максимальнй: 67
В 1-й : 78
2-й : 64
Из этих троих минимальный 64!!

Добавлено через 2 минуты
К чему сдесь 41?!
0
MILAN
888 / 782 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 13:23 #10
Как-то так, неуверен. Проверяйте

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
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
 
#define ROWS 4
#define COLS 4
 
int main()
{
        srand((unsigned)time(NULL));
        int i = 0;
        int j = 0;
        int max = 0;
        int min = 0;
        int ymax = 0;
        int xmax = 0;
        int xmin = 0;
        int ymin = 0;
        int matrix[ROWS][COLS];
 
        for(i = 0; i < ROWS; i++) {
                for(j = 0; j < COLS; j++)
                        matrix[i][j] = rand() % 100;
        }
           for(i = 0; i < ROWS; i++) {
               max = matrix[i][0];
                for(j = 0; j < COLS; j++) {
                        if(max < matrix[i][j]) {
                                max = matrix[i][j];
                                xmax = j;
                                ymax = i;
                        }
                }
            min=matrix[xmax][ymax];
 
                if(min > max) {
                        min = max;
                        xmin = xmax;
                        ymin = ymax;
                }
        }
        
        for(i = 0; i < ROWS; i++) {
                max = matrix[i][0];
                for(j = 0; j < COLS; j++) {
                        if(max < matrix[i][j]) {
                                max = matrix[i][j];
                                xmax = j;
                                ymax = i;
                        }
                }
 
                if(min > max) {
                        min = max;
                        xmin = xmax;
                        ymin = ymax;
                }
        }
 
        for(i = 0; i < ROWS; i++) {
                for(j = 0; j < COLS; j++)
                        printf("%2d ", matrix[i][j]);
 
                printf("\n");
        }
 
        printf("min: %d, x: %d, y = %d\n", min, xmin, ymin);
        getch();
        return 0;
}
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 13:35  [ТС] #11
Я все понял!!!
if(max < matrix[i][j]) туд должно быть if(max <= matrix[i][j])
А тут не if(min > max) а if(min >= max)
!!!
0
MILAN
888 / 782 / 186
Регистрация: 21.02.2009
Сообщений: 1,722
11.12.2010, 13:40 #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
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
 
#define ROWS 6
#define COLS 6
 
int main()
{
        srand((unsigned)time(NULL));
        int i = 0;
        int j = 0;
        int max = 0;
        int min = 0;
        int ymax = 0;
        int xmax = 0;
        int xmin = 0;
        int ymin = 0;
        int matrix[ROWS][COLS];
 
        for(i = 0; i < ROWS; i++) {
                for(j = 0; j < COLS; j++)
                        matrix[i][j] = rand() % 100;
        }
          max = matrix[0][0];
          for(j = 0; j < COLS; j++) 
           {
                if(max < matrix[0][j])
                    {
                        max = matrix[0][j];
                        xmax = 0;
                        ymax = j;
                    }
           }
            min = matrix[xmax][ymax];
          for(i = 0; i < ROWS; i++) 
            {
                max = matrix[i][0];
                for(j = 0; j < COLS; j++) 
                   {
                        if(max < matrix[i][j]) 
                        {
                                max = matrix[i][j];
                                xmax = j;
                                ymax = i;
                        }
                }
             if(min > max) 
                 {
                        min = max;
                        xmin = xmax;
                        ymin = ymax;
                 }
        }
 
        for(i = 0; i < ROWS; i++) {
                for(j = 0; j < COLS; j++)
                        printf("%2d ", matrix[i][j]);
 
                printf("\n");
        }
 
        printf("min: %d, x: %d, y = %d\n", min, xmin, ymin);
        getch();
        return 0;
}
0
Serhiy:)
2 / 2 / 1
Регистрация: 09.10.2010
Сообщений: 72
11.12.2010, 14:56  [ТС] #13
Спасибо за помощь, прога работает
0
11.12.2010, 14:56
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.12.2010, 14:56
Привет! Вот еще темы с решениями:

Найти и вывести на консоль минимальный элемент введённого с клавиатуры массива целых чисел
Написать программу, которая выводит минимальный элемент введенного с клавиатуры...

Найти минимальный из максимальных элементов строк
Вроде в задаче надо задействовать двумерные массивы, помогите пожалуйста. ...

Поменять местами минимальный элемент и первый отрицательный элемент массива целых чисел
Поменять местами минимальный элемент и первый отрицательный эле-мент массива...

В массиве целых чисел найти n максимальных элементов
Как массиве целых чисел размером size найти n максимальных? Добавлено через...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru