解题思路:
开始想用动态分配内存连续的二维数组,然后按照对角线依次把数字放入各个位置(先判断右上是否越界,如果未越界,则放在右上,如果右上越界,则扫描二维数组的第0列找出第一个空的位置放入),最后在把二维数组中的非零元素输出。


然...这样做好蛋疼啊,不仅要考虑非零元素不能输出,还要不停的记录上一个位置的状况。


所以,果断转换思路,寻找n*n矩阵中数字的规律,根据规律依次输出各行各列,规律有:


1.如果从零开始计数,第i行有n-i个元素,并且这n-i个元素差距依次加大,例如第0行(1 3 6 10 15),差距分别为2 3 4 5,第1行(2 5 9 14),差距分别为3 4 5。


2.每一行的起始元素之间也是有关系的,例如1 2 4 7 11,差距依次加大,分别为:1 2 3 4。

参考代码:

#include<iostream>
using namespace std;
int main(){
    int n;
    while(cin>>n){
        int begin=1;
        for(int i=0;i<n;++i){
            begin+=i;
            int going=begin;
            for(int j=0;j<n-i;++j){
                if(j!=n-i-1)cout<<going<<" ";
                else cout<<going;
                going+=(j+2+i);
            }
            cout<<endl;
        }
    }
	return 0;
}


点赞(1)
 

0.0分

11 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论