【C语言】杨氏矩阵


复制代码
#include <stdio.h>
int findnum(int* (*arr)[4], int r, int c, int k)
{
	// 先找出右上角的值
	int i = 0;
	int j = c - 1;
	while (i <= r && j >= 0)
	{
		if (k > arr[i][j])
		{
			i++;
		}
		else if (k < arr[i][j])
		{
			j--;
		}
		else
		{
			return 1;
		}
	}
	return 0;
}
int main()
{
	int arr[4][4] = { 1,2,3,4,2,3,4,5,3,4,5,6,4,5,6,7 };
	int k = 6;
	int ret = findnum(arr, 4, 4, k);
	if (ret == 1)
	{
		printf("存在!");
	}
	else
	{
		printf("不存在!");
	}
	return 0;
}
相关推荐
aduzhe12 小时前
int32 - int32MAX 出现异常
c语言·stm32
一个不知名程序员www12 小时前
算法学习入门---priority_queue(C++)
c++·算法
TL滕13 小时前
从0开始学算法——第十八天(分治算法)
笔记·学习·算法
LYFlied13 小时前
【每日算法】LeetCode 84. 柱状图中最大的矩形
前端·算法·leetcode·面试·职场和发展
CoderCodingNo13 小时前
【GESP】C++三级真题 luogu-B4414 [GESP202509 三级] 日历制作
开发语言·c++·算法
Liangwei Lin13 小时前
洛谷 P1955 [NOI2015] 程序自动分析
算法
zwjapple14 小时前
全栈开发面试高频算法题
算法·面试·职场和发展
不穿格子的程序员14 小时前
从零开始写算法——链表篇5:K个一组翻转链表 + 排序链表
算法·链表·分治
青鸟21814 小时前
从资深开发到脱产管理的心态转变
后端·算法·程序员
晨曦夜月14 小时前
笔试强训day7
开发语言·c++·算法