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。

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于 Spring Boot 博客系统开发(一)

基于 Spring Boot 博客系统开发&#xff08;一&#xff09; 本系统是简易的个人博客系统开发&#xff0c;为了更加熟练地掌握SprIng Boot 框架及相关技术的使用。&#x1f913;&#x1f913;&#x1f913; 本系统开发所需的环境及相关软件 操作系统&#xff1a;Windows Java…

面试高频:HTTPS 通信流程

更多大厂面试内容可见 -> http://11come.cn 面试高频&#xff1a;HTTPS 通信流程 HTTPS 的加密流程 接下来说一下 HTTPS 协议是如何进行通信的&#xff1a; HTTPS 通信使用的 对称加密 非对称加密 两者结合的算法 HTTPS 通信时&#xff0c;会先使用 非对称加密 让通信双…

什么是OCR转换?

OCR转换是指将图片或扫描文档中的文字内容转换成电子文本的过程。OCR代表光学字符识别&#xff08;Optical Character Recognition&#xff09;&#xff0c;是一种通过算法和模型来识别图像或文档中的文字&#xff0c;并将其转换成可编辑、可搜索的文本格式。OCR转换通常包括以…

企业常用Linux三剑客awk及案例/awk底层剖析/淘宝网cdn缓存对象分级存储策略案例/磁盘知识/awk统计与计算-7055字

高薪思维&#xff1a; 不愿意做的事情:加班&#xff0c;先例自己在利他 生活中先利他人在利自己 感恩&#xff0c;假设别人帮助过你&#xff0c;先帮助别人&#xff0c;感恩境界 awk三剑客老大 find其实也算是一种新的第四剑客 find 查找文件 查找文件&#xff0c;与其他命令…

Linux基础03-Linux文件操作命令

其实啊&#xff0c;说起计算机操作&#xff0c;大部分情况下就是“增删改查”这四个大字儿&#xff0c;文件操作也是这么回事儿。 就是改文件的时候得用点专门的编辑器&#xff0c;比如那个Vim。 不过Vim这东西&#xff0c;真心不是一两句话就能给你讲清楚的&#xff0c;咱们在…

socket套接字在tcp客户端与tcp服务器之间的通信,以及socket中常用的高效工具epoll

1.socket&#xff08;套接字&#xff09;的概念 Socket是对TCP/IP协议的封装&#xff0c;Socket本身并不是协议&#xff0c;而是一个调用接口&#xff08;API&#xff09;&#xff0c;通过Socket&#xff0c;我们才能使用TCP/IP协议,主要利用三元组【ip地址&#xff0c;协议&am…

STM32F1之I2C通信

目录 1. 简介 2. 硬件电路 3. IIC时序基本单元 3.1 发送一个字节 3.2 接收一个字节 3.3 发送应答 3.4 接收应答 1. 简介 I2C&#xff08;Inter-Integrated Circuit&#xff09;总线是由NXP Semiconductors&#xff08;前身为Philips Semiconductor&#xff09;…

【C++初阶】vector使用特性 vector模拟实现

1.vector的介绍及其使用 1.1 vector的介绍 vector文档介绍 1. vector是表示可变大小数组的序列容器。 2. 就像数组一样&#xff0c;vector也采用的连续存储空间来存储元素。也就是意味着可以采用下标对vector的元素进行访问&#xff0c;和数组一样高效。但是又不像数组&#…

浏览器数据找回

网站上分享的文章应该都是个人的心血&#xff0c;对于一些操作问题导致心血丢失真的很奔溃&#xff0c;终于找到一个弥补的办法&#xff0c;csdn的文章谷歌浏览器亲测有效&#xff0c;理论上其他浏览器的其他网站应该也可以&#xff0c;适用以下场景 把博客编辑当成了编写新博…

ELK 日志分析(二)

一、ELK Kibana 部署 1.1 安装Kibana软件包 #上传软件包 kibana-5.5.1-x86_64.rpm 到/opt目录 cd /opt rpm -ivh kibana-5.5.1-x86_64.rpm 1.2 设置 Kibana 的主配置文件 vim /etc/kibana/kibana.yml --2--取消注释&#xff0c;Kiabana 服务的默认监听端口为5601 server.po…

ARM与单片机有啥区别?

初学者必知&#xff1a;ARM与单片机到底有啥区别&#xff1f;1、软件方面这应该是最大的区别了。引入了操作系统。为什么引入操作系统&#xff1f;有什么好处嘛&#xff1f; 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「ARM的资料从专业入门到高级教…

如何扛过人生的至暗时刻,获得幸福人生?

人生的至暗时刻是每个人在成长过程中都可能遇到的经历&#xff0c;它们可能包括失去亲人、失业、健康问题、情感破裂或其他形式的个人危机。在这些时刻&#xff0c;我们可能会感到绝望、孤独和无助。然而&#xff0c;正是在这些挑战中&#xff0c;我们也有机会学习如何变得更坚…

VUE运行找不到pinia模块

当我们的VUE运行时报错Module not found: Error: Cant resolve pinia in时 当我们出现这个错误时 可能是 没有pinia模块 此时我们之要下载一下这个模块就可以了 npm install pinia

同旺科技 USB TO SPI / I2C适配器读写24LC128--读写

所需设备&#xff1a; 1、USB 转 SPI I2C 适配器&#xff1b;内附链接 2、24LC128芯片&#xff1b; 适应于同旺科技 USB TO SPI / I2C适配器专业版&#xff1b; 专业版配套软件更新&#xff1b; 直接读取HEX文件&#xff0c;自动完成文件解析&#xff1b; 支持芯片&#xf…

【编程Tool】VS code安装与使用配置保姆级教程

目录 1.软件介绍 2.软件下载&#xff1a; 3.安装 3.1. 双击可执行文件 3.2. 同意协议 3.3. 选择安装路径&#xff0c;默认在C盘 3.4. 点击下一步 3.5. 可选择所有附加任务 3.6. 点击安装 3.7. 等待安装 3.8. 点击完成 3.9. 安装成功 4.下载MinGW64 4.1. MinGW-64下载地址 &…

《深入浅出.NET框架设计与实现》笔记2——C#源码从编写到执行的流程

中间语言&#xff08;Intermediate Language&#xff0c;IL&#xff09; C#编译器在编译时&#xff0c;会将源代码作为输入&#xff0c;并以中间语言形式输入出&#xff0c;该代码保存在*.exe文件中或*.dll文件中。 公共语言运行时&#xff08;CLR&#xff09; 可以将IL代码…

控制与估计的融合 —— 自抗扰控制

一、自抗扰控制—控制与估计融合 控制理论中的控制与估计是互为对偶的概念&#xff0c;二者在系统控制过程中相辅相成&#xff0c;共同实现了对系统状态的精确管理和优化控制。自抗扰控制&#xff08;Adaptive Disturbance Rejection Control, ADRC&#xff09;技术是将控制与…

天星金融(原小米金融)履行社会责任,提高社保政策知晓度

二十大报告指出“为民造福是立党为公、执政为民的本质要求“&#xff0c;人民幸福安康是推动高质量发展的最终目的。社会保障作为维护社会公平、增进人民福祉的基本制度&#xff0c;既是“安全网”也是“稳定器”&#xff0c;发挥着改善民生的重要作用。为进一步提升人民群众对…

230基于matlab的布谷鸟(COA)多目标优化算法

基于matlab的布谷鸟&#xff08;COA&#xff09;多目标优化算法&#xff0c;以 满意度、成本、时间、质量为目标的多目标优化求解代码。程序已调通&#xff0c;可直接运行。 230 matlab 布谷鸟&#xff08;COA&#xff09;多目标优化 - 小红书 (xiaohongshu.com)

使用spring boot集成shardingsphere分库分表简易测试

根据如下pom整上一个spring-boot项目&#xff0c;spring-boot版本用2.3.5&#xff0c;shardingsphere用5.1.1。 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://ww…