牛客网刷题 ——C语言初阶(6指针)——BC106 上三角矩阵判定

1. 题目描述------BC106 上三角矩阵判定

牛客网OJ题链接

描述

KiKi想知道一个n阶方矩是否为上三角矩阵,请帮他编程判定。上三角矩阵即主对角线以下的元素都为0的矩阵,主对角线为从矩阵的左上角至右下角的连线。

示例

输入:

3

1 2 3

0 4 5

0 0 6

输出:YES

2. 思路

3. 代码实现

c 复制代码
#include<stdio.h>
int main()
{
	int n = 0;
	scanf("%d", &n);
	int i = 0,j = 0;
	int arr[10][10] = { 0 };
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < n; j++)
		{
			scanf("%d", &arr[i][j]);
		}
	}

	int k = 0;
	int t = 0;
	int flag = 1;
	for (k = 0; k < n; k++)
	{
		for (t = 0; t < k; t++)
		{
			if (arr[k][t] != 0)
			{
				flag = 0;
			}
		}
	}
	if (flag == 1)
	{
		printf("YES\n");
	}
	else
	{
		printf("NO\n");
	}



	return 0;

4. 代码实现2

这个加入了goto 语句,因为如果我们已经判断不等于0,就不需要判断剩余的了

c 复制代码
#include<stdio.h>
int main() {
    int n = 0;
    scanf("%d", &n);
    int i = 0, j = 0;
    int arr[10][10] = { 0 };
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            scanf("%d", &arr[i][j]);
        }
    }

    int k = 0;
    int t = 0;
    int flag = 1;
    for (k = 0; k < n; k++) {
        for (t = 0; t < k; t++) {
            if (arr[k][t] != 0) {
                flag = 0;
                goto end;
            }
        }
    }
end:
    if (flag == 1) {
        printf("YES\n");
    } else {
        printf("NO\n");
    }



    return 0;
}

5.代码实现3

我们也可以不使用goto,当判断我们有值不等于0的时候,直接打印NO,然后return。

c 复制代码
#include<stdio.h>
int main() {
    int n = 0;
    scanf("%d", &n);
    int i = 0, j = 0;
    int arr[10][10] = { 0 };
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            scanf("%d", &arr[i][j]);
        }
    }

    int k = 0;
    int t = 0;
    for (k = 0; k < n; k++) {
        for (t = 0; t < k; t++) {
            if (arr[k][t] != 0) {
                printf("NO\n");
                return 0;
            }
        }
    }


    printf("YES\n");
    return 0;
}

6. 代码实现4,其实并不需要再创建两个循环变量,都使用i和j是没问题的,因为我们会给i,j重新赋值为0

c 复制代码
#include<stdio.h>
int main() {
    int n = 0;
    scanf("%d", &n);
    int i = 0, j = 0;
    int arr[10][10] = { 0 };
    for (i = 0; i < n; i++) {
        for (j = 0; j < n; j++) {
            scanf("%d", &arr[i][j]);
        }
    }


    for (i = 0; i < n; i++) {
        for (j = 0; j < i; j++) {
            if (arr[i][j] != 0) {
                printf("NO\n");
                return 0;
            }
        }
    }


    printf("YES\n");
    return 0;
}
相关推荐
上弦月-编程7 小时前
递归实现C语言菱形图案打印
c语言
Mrlxl.cn7 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
叶子野格9 小时前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
一口Linux10 小时前
Linux C编程 | 从0实现telnet获取程序终端控制权
linux·运维·c语言
Mrlxl.cn10 小时前
计算机网络——传输层
c语言·计算机网络·考研·排序算法
aacd271910 小时前
C语言之预处理详解ヾ(•ω•`)o
c语言·学习
handler0111 小时前
Linux 进程探索:从 PCB 管理到 fork() 的写时拷贝
linux·c语言·c++·笔记·学习
宣宣猪的小花园.12 小时前
C语言重难点全解析:指针到内存四区
c语言·开发语言
老花眼猫13 小时前
三角函数绘制椭圆和椭圆旋转
c语言·经验分享·青少年编程·课程设计
代码中介商13 小时前
C语言操作符深度解析:从基础到高级应用
c语言·开发语言