Форум программистов, компьютерный форум, киберфорум
Наши страницы
C для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
Шмебулок
0 / 0 / 0
Регистрация: 21.10.2018
Сообщений: 36
1

На побочной диагонали матрицы поменять местами первый максимальный и последний минимальный элементы

19.11.2018, 17:50. Просмотров 800. Ответов 1
Метки си (Все метки)

В этой задачи задана матрица вещественных чисел A[n][n].Нужно в побочной диагонеале матрицы найти первый максимальный и последний минимальный елементы и поменять их местами.Я в главной диагонале нашел первый минимальный и последний максимальный и поменял их местами, как переписать код правильно?



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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(){
const int n=8;
int A[n][n];
int min, max, i, j, a;
srand (time (0));
printf ("Initial matrix: \n");
for(i=0; i<n; i++){
    for(j=0; j<n; j++){
        A[i][j]=rand ()  %11 -5 ;
        printf("%3i", A[i][j]);
        printf ("  ");
}
printf("\n\n");
}
max=min=0;
for(i=0; i<n; i++){
    if (A[i][i]<A[min][min])
    min=i;
        else if (A[i][i]>=A[max][max])
        max=i;
}
    a=A[min][min];
    A[min][min]=A[max][max];
    A[max][max]=a;
    printf ("New matrix: \n");
    for(i=0; i<n; i++){
        for(j=0; j<n; j++){
            printf("%3i", A[i][j]);
            printf ("  ");
}
    printf ("\n\n");
}
return 0;
}
0
Лучшие ответы (1)
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2018, 17:50
Ответы с готовыми решениями:

Как поменять местами последний нулевой элемент и первый максимальный элементы?
Как поменять местами последний нулевой элемент и первый максимальный элементы?

На побочной диагонали матрицы найти максимальный и минимальный элементы
Дана квадратная матрица размером 6х6.На побочной диагонали найти максимальный и минимальный...

На побочной диагонали матрицы найти максимальный и минимальный элементы
Дана квадратная матрица размером 6х6.На побочной диагонали найти максимальный и минимальный...

Поменять местами максимальный и минимальный элемент главной диагонали матрицы
В квадратной матрице размером 5х5 узнать максимальный и минимальный элемент главной диагонали....

Найти минимальный элемент каждого столбца матрицы и поменять его местами с элементом побочной диагонали
Уважаемые форумчане , прошу помочь с программой данного содержания: &quot;Дана квадратная матрица, в...

1
ft4l
Невнимательный
433 / 357 / 126
Регистрация: 08.02.2013
Сообщений: 1,001
Записей в блоге: 2
19.11.2018, 23:17 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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(){
const int n=8;
int A[n][n];
int min, max, i, j, a;
srand (time (0));
printf ("Initial matrix: \n");
for(i=0; i<n; i++){
    for(j=0; j<n; j++){
        A[i][j]=rand ()  %11 -5 ;
        printf("%3i", A[i][j]);
        printf ("  ");
}
printf("\n\n");
}
max=min=0;
 
for(i=0; i<n; i++){
    if (A[n-i-1][i]<A[n-min-1][min])
    min=i;
    else if (A[n-i-1][i]>=A[n-max-1][max])
    max=i;
}
 
    a=A[n-min-1][min];
    A[n-min-1][min]=A[n-max-1][max];
    A[n-max-1][max]=a;
    printf ("New matrix: \n");
 
    for(i=0; i<n; i++){
        for(j=0; j<n; j++){
            printf("%3i", A[i][j]);
            printf ("  ");
}
    printf ("\n\n");
}
return 0;
}
если слева A[i][n-i-1] использовать вместо A[n-i-1][i]

Добавлено через 24 минуты
вообще-то ошибаюсь, можно просто поменять в проверках < на <= и >= на >
, хотя удобнее с указателями min-max
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main(){
const int n=8;
int A[n][n];
int *min, *max, i, j, a;
srand (time (0));
printf ("Initial matrix: \n");
for(i=0; i<n; i++){
    for(j=0; j<n; j++){
        A[i][j]=rand ()  %11 -5 ;
        printf("%3i", A[i][j]);
        printf ("  ");
}
printf("\n\n");
}
min=&A[n-1][0];
max=&A[0][n-1];
 
for(i=0, j=n-1; i<n; i++,j--){
    if (A[j][i]<*min)       min=&A[j][i];
    else if (A[j][i]>=*max) max=&A[j][i];
}
 
    a=*min;
    *min=*max;
    *max=a;
    printf ("New matrix: \n");
 
    for(i=0; i<n; i++){
        for(j=0; j<n; j++){
            printf("%3i", A[i][j]);
            printf ("  ");
}
    printf ("\n\n");
}
return 0;
}
1
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.11.2018, 23:17

Поменять местами элементы лежащие вдоль побочной диагонали матрицы
дана нечетная матрица n * m. поменять местами элементы лежащие вдоль побочной диагонали. ...

Поменять местами минимальный и максимальный элементы матрицы
Дана матрица размером 4х5. Поменять местами минимальный и максимальный элементы матрицы. Матрицу, я...

Поменять местами минимальный и максимальный элементы матрицы
Дана матрица размером 4х5. Поменять местами минимальный и максимальный элементы матрицы. Матрицу, я...


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

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

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