C - 矩阵主对角线和替换对角线(替换)

时间:2017-12-07 16:02:40

标签: c matrix replace diagonal

我有一项任务,我需要专业人士的帮助。

我的任务是:用户输入矩阵[8] [8]的行数和列数,并禁止使用IF。稍后用户输入该矩阵的所有元素,使用循环并输出该矩阵。

以下是代码:

#include <stdio.h>

int main () 
{
    int matrix[10][10];
    int nrows, ncols, i, j;

    printf("Enter number of rows: "); //user enters number of rows
    scanf("%d", &nrows);
    if(nrows < 4){
        printf("\n Out of range, please try again");
        exit(5);
    }
    printf("Enter number of columns: "); //user enters number of columns
    scanf("%d", &ncols);
    if(ncols < 4){
        printf("\n Out of range, please try again");
        exit(5);
    }
    printf("Enter matrix elements: "); //user enters all the elements for Matrix

    for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
            scanf("%d",&matrix[i][j]);
    }

    printf("\n");
}
    printf("This is your matrix: \n");
    for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
            printf("%d \t",matrix[i][j]);}

    printf("\n");}



    return 0;   
}

现在我需要添加一个东西,我想采用这个矩阵的对角线和反对角线,并用大写X替换那里的所有元素。 我不知道它会是什么样的矩阵,就像它可以是矩阵[4] [6]或矩阵[7] [4],所以我需要做一些适用于任何类型矩阵的东西用户可以输入此程序。

这个任务的例子(在这个程序中我不能输入少于[4] [4],但是对于我将要做的例子):

User enters rows - 3
User enters columns - 3
User enters elements : 1 2 3 4 5 6 7 8 9
Output :

    1 2 3
    4 5 6
    7 8 9

我需要做这样的事情:

X 2 X
4 X 6
X 8 X

如果用户输入的不是方形矩阵,例如:

User enters rows: 3
User enters rows: 4
User enters elements: 1 2 3 4 5 6 7 8 9

Out matrix: 

1 2 3 4
5 6 7 8
9 0 1 2

After replacing with X:

X 2 3 X
5 X X 8
9 X X 2

用大写X替换对角线和反对角线。

请帮忙吗?

2 个答案:

答案 0 :(得分:1)

您可以这样做:

    printf("This is your matrix: \n");
for(i = 0; i < nrows; i++){
    for(j = 0; j < ncols; j++){
        if (i == j)
            printf("X \t");
        else if (i == ncols - j - 1)
            printf("X \t");
        else
            printf("%d \t", matrix[i][j]);
    }

    printf("\n");}

示例:

Enter number of rows: 4
Enter number of columns: 5
Enter matrix elements: 1 1 1 1 1 2 2 2 2 2 3 3 3 3 3 4 4 4 4 4




This is your matrix: 
X   1   1   1   X   
2   X   2   X   2   
3   3   X   3   3   
4   X   4   X   4 

答案 1 :(得分:0)

完整的代码及其在您所提供的两个示例中的工作,只需告诉我这里是否有任何遗漏

#include <stdio.h>

int main ()
{
    int matrix[10][10];
    int nrows, ncols, i, j;

    printf("Enter number of rows: "); //user enters number of rows
    scanf("%d", &nrows);
    if(nrows < 4){
        printf("\n Out of range, please try again");
        exit(5);
    }
    printf("Enter number of columns: "); //user enters number of columns
    scanf("%d", &ncols);
    if(ncols < 4){
        printf("\n Out of range, please try again");
        exit(5);
    }
    printf("Enter matrix elements: "); //user enters all the elements for Matrix

    for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
            scanf("%d",&matrix[i][j]);
    }

    printf("\n");
}
    printf("This is your matrix: \n");
    for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
            printf("%d \t",matrix[i][j]);}

    printf("\n");}
//When square matrix
    if(nrows==ncols)
    {
        for(i = 0; i < nrows; i++){
           matrix[i][i]='X';
            }
            int count=0;
            for(i=nrows-1;i>=0;i--)
            {
                matrix[count][i]='X';
                count++;

            }
 for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
                if(i==j||(i+j==nrows-1))
            printf("%c \t",matrix[i][j]);
        else
                        printf("%d \t",matrix[i][j]);

            }

    printf("\n");}
    }
else
{
    if(nrows<ncols)
    {
        int count=ncols-1;
        for(i = 0; i < nrows; i++){
           matrix[i][i]='X';
            }
            for(i = 0; i < nrows; i++){
           matrix[i][count]='X';
           count--;
            }
          for(i = 0; i < nrows; i++){
        for(j = 0; j < ncols; j++){
                if(i==j||(i+j==nrows))
                printf("%c \t",matrix[i][j]);
        else
                                    printf("%d \t",matrix[i][j]);



            }

    printf("\n");}
    }

}

    return 0;
}