【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;
}
相关推荐
骑着猪去兜风.1 小时前
线段树(二)
数据结构·算法
fengfuyao9852 小时前
竞争性自适应重加权算法(CARS)的MATLAB实现
算法
薛慕昭2 小时前
嵌入式 C 语言猜大小游戏设计与实现
c语言·游戏
散峰而望2 小时前
C++数组(二)(算法竞赛)
开发语言·c++·算法·github
leoufung2 小时前
LeetCode 92 反转链表 II 全流程详解
算法·leetcode·链表
wyhwust3 小时前
交换排序法&冒泡排序法& 选择排序法&插入排序的算法步骤
数据结构·算法·排序算法
利刃大大3 小时前
【动态规划:背包问题】完全平方数
c++·算法·动态规划·背包问题·完全背包
月光技术杂谈3 小时前
实战:C驱动框架嵌入Rust模块的互操作机制与完整流程
c语言·开发语言·rust·ffi·跨语言·bindgen·互操作
wyhwust3 小时前
数组----插入一个数到有序数列中
java·数据结构·算法
im_AMBER3 小时前
Leetcode 59 二分搜索
数据结构·笔记·学习·算法·leetcode