C语言练习——上三角矩阵

       前言

         今天我们来看看如何使用代码实现上三角矩阵吧。首先我们来了解一下上上三角矩阵是什么,上三角矩阵就是在矩阵从左上到右下的对角线之下的数组元素都为0的数组方矩阵,例如:

        

        以一个三阶矩阵为例,在对角线元素之下,就是红色圈圈圈起来的那里,元素都为0,那么这个三阶矩阵就是上三角矩阵。

        题目描述

        杰克有一天在学习线性代数的时候突然想到,可不可以使用C语言编程来实现一个上三角矩阵,请帮助杰克判断一个n阶方矩是否为上三角矩阵。上三角矩阵即主对角线以下的元素都为0的矩阵,主对角线为从矩阵的左上角至右下角的连线。

        输入描述:

        第一行包含一个整数n,表示一个方阵包含n行n列,用空格分隔。 (1≤n≤10)

        从2到n+1行,每行输入n个整数(范围-231~231-1),用空格分隔,共输入n*n个数。

        输出描述:

        一行,如果输入方阵是上三角矩阵输出"YES"并换行,否则输出"NO"并换行。

        代码实现

        

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{int n = 0;//定义输入的是几阶的矩阵printf("请输入矩阵阶数\n");scanf("%d", &n);int arr[20][20];int i = 0;    //输入数组中元素for (i = 0;i < n;i++){int j = 0;for (j = 0;j < n;j++){scanf("%d", &arr[i][j]);}}//默认上三角矩阵int flag = 1;for (i = 0;i < n;i++){int j = 0;for (j = 0;j < i;j++){if (arr[i][j] != 0){//判断不是上三角矩阵flag = 0;//goto语句结束程序,跳转到end,不使用break的原因是break只能跳出当前循环,这里有使用循环的嵌套,不能完全跳出。goto end;}}}
//编辑end,判断flag状态并输出
end:if (flag == 1){printf("YES\n");}if (flag == 0){printf("NO\n");}return 0;
}

        代码解释

        矩阵阶数

        我们想要实现题目中的要求首先需要输入一个数组,这个数组要足够大,大到可以存放需要输入的元素,题目中要求n的范围是0~10,那么我们就将矩阵设置为最大行和列设置为20吧,定义二维数组arr用来存放我们想要存放的元素,完成矩阵的建立,我们在输入整个矩阵前需要先输入一个n来说明我们这次要判断的上三角矩阵是几阶的。

        输入矩阵

        之后我们确定好了几阶的矩阵就要向矩阵里面输入内容了,我们使用一个for循环的嵌套分别遍历整个矩阵,先行后列的方式,之后我们只需要使用输入函数scanf()来对矩阵内元素arr[i][j]进行输入就好。

        判断矩阵是否为上三角矩阵

        矩阵输入完成之后,我们就需要判断我们输入的矩阵是否为一个上三角矩阵了,我们如何判断呢,让我们仔细来看看这个矩阵,假设n=3,

        

        在图中我们发现,以主对角线划分(0,0)(1,1)(2,2),在主对角线往下的的元素i>j,在主对角线往上的元素中i<j,那么根据这个性质,我们来判断主对角线往下的元素是不是都为0,如果是,那么这个矩阵就是上三角矩阵。

        我们还是遍历一遍数组,但是这次遍历又和之前有所区别,我们先使用for循环遍历行,之后在列的时候注意了,我们需要重置一下j,使j=0,之后这里我们for循环内部的判断条件只需要写为j<i就可以,这样我们就可以找到主对角线往下的元素了,之后判断这些元素是否不为0;如果不为0,就证明这个矩阵不是上三角矩阵。        

        flag的使用

        在此之前,我们判断矩阵的第一个for循环之前设置flag = 1,它的作用是:假设现在我们遍历的矩阵是一个上三角矩阵。之后判断结束,矩阵不是上三角矩阵,我们将flag置为0表示为假。

        goto语句与break语句

        之后我们使用goto语句跳出循环,设置跳转语句为end,有些小伙伴疑惑了,为什么我们不使用break呢,因为这里使用了for循环的嵌套,当我们使用break跳出当前循环的时候,外面还有一个循环,我们就还需要对外层循环进行其他操作,所以我们直接使用goto语句跳转到end跳出循环即可。

        编辑end,假如flag=1的话,矩阵为上三角矩阵,那么我们就输出YES,如果flag=0的话,那么矩阵不是上三角矩阵,输出NO。

        今天就到这里喽,加油加油!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/637848.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Hadoop】- YARN概述[6]

目录 一、YARN & Reduce 二、分布式资源调度 - YARN 1、资源调度 2、YARN的资源调度 总结 一、YARN & Reduce MapReduce是基于YARN运行的&#xff0c;即没有YARN “无法” 运行MapReduce程序。 二、分布式资源调度 - YARN YARN&#xff08;Yet Another Resou…

springboot是什么?

可以应用于Web相关的应用开发。 选择合适的框架&#xff0c;去开发相关的功能&#xff0c;会有更高的效率。 为什么Spring Boot才是你该学的!学java找工作必会技能!在职程序员带你梳理JavaEE框架_哔哩哔哩_bilibili java工程师的必备技能 Spring是Java EE领域的企业级开发宽…

Golang汇编之通过map地址找到value的值

文章目录 背景gdb调试Go程序为什么不用dlvgdb调试Go可执行程序gdb打印地址内容 go汇编快速入门常用的寄存器和用法AMD64ARM64loong64riscv64 Go汇编常用命令及含义Go汇编和x86的区别找到map的赋值指令 Go中map的内存布局gdb中查看map结构map的存储结构map的内存布局计算bmap偏移…

【深度学习-番外1】Win10系统搭建VSCode+Anaconda+Pytorch+CUDA深度学习环境和框架全过程

专栏的老读者们都知道&#xff0c;以前的文章以使用MATLAB的为多。 不过后续陆续开始展开深度学习算法的应用&#xff0c;就会逐渐引入Python语言了&#xff08;当然MATLAB的代码也会同步更新&#xff09;&#xff0c;这是由于在深度学习领域&#xff0c;Python应用更为广泛。…

uni-app为图片添加自定义水印(升级版)

前置内容 uni-app为图片添加自定义水印&#xff08;解决生成图片不全问题&#xff09; UI 升级 现在水印样式变成这样了&#xff1a; 代码 <template><canvas v-if"waterMarkParams.display" canvas-id"waterMarkCanvas" :style"canv…

如何使用JSONB类型在PostgreSQL中存储和查询复杂的数据结构?

文章目录 解决方案1. 创建包含JSONB列的表2. 插入JSONB数据3. 查询JSONB数据4. 创建索引以优化查询性能 示例代码结论 在PostgreSQL中&#xff0c;JSONB是一种二进制格式的JSON数据类型&#xff0c;它允许你在数据库中存储和查询复杂的JSON数据结构。与普通的JSON类型相比&…

Springboot的Test单元测试操作

Springboot的Test单元测试操作 简单总结需要操作的步骤 1&#xff0c;导入依赖 2&#xff0c;创建目录&#xff08;目录和启动类的目录保持一致&#xff09; 3&#xff0c;添加注解 4&#xff0c;写方法测试 1&#xff0c;导入依赖 <dependency><groupId>org.spri…

Ts支持哪些类型和类型运算(下)

目录 1、条件判断 &#xff08;extends &#xff1f;&#xff09; 2、推导 infer 3、联合 | 4、交叉 & 5、映射类型 1、条件判断 &#xff08;extends &#xff1f;&#xff09; ts里的条件判断&#xff0c;语法为 T extends XXX ? true : false &#xff0c;叫做…

Docker - WEB应用实例

原文地址&#xff0c;使用效果更佳&#xff01; Docker - WEB应用实例 | CoderMast编程桅杆Docker - WEB应用实例 在之前的章节中&#xff0c;仅对普通容器进行了演示&#xff0c;但在实际中常常使用到 Docker 容器中的 WEB 应用程序。 运行一个WEB应用 拉取镜像 创建一个容器…

ROS机器人实战,对标古月老师HRMRP机器人(一)——机器人总体方案设计

咳咳&#xff01;这个是自己的毕业设计&#xff0c;内容比较多就拆开发。设计实现了一款SLAM移动机器人&#xff0c;加机械臂完成视觉识别抓取的&#xff0c;同时还有语音识别控制、QT上位机控制、Web网页控制。前几年看古月老师的视频&#xff0c;看到古月老师设计的HRMRP&…

Hadoop1X,Hadoop2X和hadoop3X有很大的区别么?

Hadoop的演进从Hadoop 1到Hadoop 3主要是为了提供更高的效率、更好的资源管理、更高的可靠性以及对更多数据处理方式的支持。下面是Hadoop 1, Hadoop 2, 和 Hadoop 3之间的主要区别和演进的原因&#xff1a; Hadoop 1 特点&#xff1a; 主要包括两大核心组件&#xff1a;HDFS&a…

【Hadoop】-HDFS的Shell操作[3]

目录 前言 一、HDFS集群启停命令 1.一键启停脚本可用 2.独立进程启停可用 二、文件系统操作命令 1、创建文件夹 2、查看指定目录下内容 3、上传文件到HDFS指定目录下 4、查看HDFS文件内容 5、下载HDFS文件 6、拷贝HDFS文件 7、追加数据到HDFS文件中 8、HDFS数据移…