输出平方矩阵

题目:

输入一个正整数n,输出一个n阶的平方矩阵。

例如:

输入:5

输出:

1 4 9 16 25 
4 9 16 25 1 
9 16 25 1 4 
16 25 1 4 9 
25 1 4 9 16 

解题思路:

本题我分别采用一维数组和二维数组来实现。

一维数组:采用一维数组输出矩阵的形式,我考虑的是一行一行的进行输出,输出一次进行一次一位数组的移动,然后再进行输出,重复这个过程。

二维数组:利用二维数组实现的过程中,我主要观察输出结果找规律实现。因为采用的是二维数组,所以我找到行标、列标与对应值的关系:a[i][j] =(i+j+1)*(i+j+1),这个规律适用于矩阵的副对角线之上的元素。在矩阵的副对角线之下,元素同样可以表示为a[i][j] = k * k的形式,但此时的k = (i+j+1)%n。

程序代码:

使用一位数组实现: 

#include <stdio.h>
//一维数组实现平方矩阵
int main(int argc, char *argv[])
{ 
    int n, i, temp, j;
    printf("你想输出几行几列的平方矩阵:");
    scanf("%d",&n);
    int a[n];
    for(i = 0; i < n; i++){//赋值
        a[i] = (i+1) * (i+1);
    }
    for(j = 0; j < n; j++){//移动次数
        if(j > 0){
            temp = a[0];//取第一个元素
            for(i = 0; i < n - 1; i++){//移动
                a[i] = a[i+1];
            }
            a[n-1] = temp;}//将第一个元素移动到最后一个位置
        for(i = 0; i < n; i++){//输出
            printf("%d ",a[i]);
        }
        putchar('\n');
    }
    return 0;
} 

使用二维数组实现: 

#include <stdio.h>
//二维数组输出平方矩阵
int main(int argc, char *argv[])
{ 
    int n, i, j, k;
    printf("你想输出几行几列的平方矩阵:");
    scanf("%d",&n);
    int a[n][n];
    for(i = 0; i < n; i++){
    for(j = 0; j < n; j++){
        k = i + j + 1;
        if(i + j >= n){//取余修正输出结果
        k %= n;
        }
    a[i][j] = k * k;
    printf("%d ",a[i][j]);
    }
    putchar('\n');
    }
    return 0;
} 

运行结果:

你想输出几行几列的平方矩阵:5
1 4 9 16 25 
4 9 16 25 1 
9 16 25 1 4 
16 25 1 4 9 
25 1 4 9 16 
你想输出几行几列的平方矩阵:10
1 4 9 16 25 36 49 64 81 100 
4 9 16 25 36 49 64 81 100 1 
9 16 25 36 49 64 81 100 1 4 
16 25 36 49 64 81 100 1 4 9 
25 36 49 64 81 100 1 4 9 16 
36 49 64 81 100 1 4 9 16 25 
49 64 81 100 1 4 9 16 25 36 
64 81 100 1 4 9 16 25 36 49 
81 100 1 4 9 16 25 36 49 64 
100 1 4 9 16 25 36 49 64 81 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值