标识性数组的应用(7-1判断上三角矩阵 )

实验过程分析:该题实现了矩阵是否为上阶梯,下阶梯的作用,矩阵是一个有行又有列的特征数列,此时我们就不难去想到用二维数组来存储对应的行和列,同时根据之前的经验,我们需要两个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");

         }

}

如有不好的地方,希望你能指正。加油加油💪。

如果感觉还可以,可以留个赞吗,需要点原动力😁。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值