实验过程分析:该题实现了矩阵是否为上阶梯,下阶梯的作用,矩阵是一个有行又有列的特征数列,此时我们就不难去想到用二维数组来存储对应的行和列,同时根据之前的经验,我们需要两个for循环一个管行一个管列,通过实践,我也发现了,二维数组的输入和输出都需要至少两个循环,在此我们又看到是先输入3组数据,然后他一口气给判断出来,当时我在想,莫非需要三个二维数组?但是我又想他并没有给N,所以用多个数组的想法肯定不行,如果只用一个数组的话,我们就不得不进行数值的覆盖,想到这里,我又想,怎么去记录他是否为Yes?还是No呢?主要我又不知道他要定义几个变量,此时我就又想到了数组,因为数组能储存结果,如果我们能让一个数组储存结果的话,我们在这里姑且先叫他标识数组,这个数组记录了当时每个数据的辉煌功绩,从这里我也学到了。标识开关的不仅仅只有变量,原来还有我们的数组。那接下来就好说多了,我们首先用两个for来让这个矩阵里面的东西全部到数组里面,我们让flag的初始值为1,如果他的对角线下面有非零的我们就让flag=0,这样以来我们就可以知道他到底是不是上三角了,flag要在赋值和判断for的外层,同时又在输入几个矩阵的for里面,在这里,通过i=0和j=0我真正体会到了二维数组的赋值方法,i从0不断增加,他增加一次,那么j就增加row次,这样一来就实现了数组中所有元素的遍历,也就给每一个都赋了值,最后也是用for来遍历b[]中的元素,这里面的元素为1,也就是说是YES,元素为0就是NO。
上代码:
#include <stdio.h>
int main(){
int number,row,i,j,k,l,a[10][10],b[10];//a来统计矩阵元素,b则是来当标识数组
int flag;
scanf("%d",&number);
for(i=0;i<number;i++){//看你想要输入几个矩阵
scanf("%d",&row);//判断你要输出几阶方阵,由于输入完一个矩阵就要判断所以放到for里面
for(j=0;j<row;j++){/控制行,也就是二维数组的第一个[]
flag=1;//判断是否为上三角矩阵
for(k=0;k<row;k++){
scanf("%d",&a[j][k]);//把矩阵中数的全部弄到数组里面来
}
}
for(j=0;j<row;j++){//行
for(l=0;l<j;l++){//列
if(j>0){
if(a[j][l]!=0)flag=0;;//如果对角线下面有一个不为0的我们就把flag弄成0,方便后续的打印出来YES或者NO。
}
else continue;//实际上这句话可有可无,可是不加我有感觉心里少点什么。
}
}
b[i]=flag;//把flag的值给b数组,这样就储存了YES或者NO了,也就是储存了结果。
}
for(i=0;i<number;i++){//遍历b数组并打印出相应结果,标识性数组主要是解决这种必须先打一对数据,然后还不给你反馈的一些程序,通常和变量勾肩搭背。
if(b[i]==1)printf("YES\n");
else if(b[i]==0)printf("NO\n");
}
}
如有不好的地方,希望你能指正。加油加油💪。
如果感觉还可以,可以留个赞吗,需要点原动力😁。