牛客网刷题 ——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;
}
相关推荐
南棱笑笑生3 小时前
20251217给飞凌OK3588-C开发板适配Rockchip原厂的Buildroot【linux-5.10】后调通ov5645【只能预览】
linux·c语言·开发语言·rockchip
aduzhe4 小时前
int32 - int32MAX 出现异常
c语言·stm32
摘星编程7 小时前
Ascend C编程语言详解:打造高效AI算子的利器
c语言·开发语言·人工智能
自然常数e7 小时前
深入理解指针(6)
c语言·数据结构·算法·visual studio
一杯美式 no sugar7 小时前
数据结构——栈
c语言·数据结构·
CQ_YM9 小时前
Linux线程控制
linux·c语言·开发语言·线程
lingran__9 小时前
C语言字符函数和字符串函数详解
c语言·开发语言
white-persist10 小时前
【攻防世界】reverse | simple-check-100 详细题解 WP
c语言·开发语言·汇编·数据结构·c++·python·算法
☆cwlulu11 小时前
C/C++ 内存分配函数详解
c语言·c++
程芯带你刷C语言简单算法题13 小时前
Day30~实现strcmp、strncmp、strchr、strpbrk
c语言·学习·算法·c