一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - C語言面試C++二維數組中的查找示例

C語言面試C++二維數組中的查找示例

2022-01-17 14:47小碼農UU C/C++

這篇文章主要介紹了C語言面試C++二維數組中的查找示例,文中給出基本能拿下面試官的操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助

二維數組中的查找

面試題3:

C語言面試C++二維數組中的查找示例

似題:

我做過這個類似的有楊氏矩陣為背景的,實際上是一樣的

暴力遍歷

二維數組暴力遍歷的話時間復雜度為O(n2)

雖然暴力但是應付學校考試這個就是一把好手

#include<stdio.h>
//const 就是因為二維數組是定死的
int search(const int arr[4][4], int num,unsigned int* prow,unsigned int* pcol)
{
	int i = 0;
	//掃描行
	for (i = 0; i < *prow; i++)
	{
		//掃描列
		int j = 0;
		for (j = 0; j < *pcol; j++)
		{
			//與所查數比較判斷,有一樣的就直接返回
			if (arr[i][j] == num)
			{
				*prow = i;//把坐標傳回去
				*pcol = j;
				return 1;//一次返回,之后就不看了,因為已經證明到有這個數了,沒必要在做無用功了
			}
		}
	}
	return 0;
}
int main()
{
	int arr[4][4] = { {1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15} };
	int num = 0;
	while (1)
	{
		unsigned int row = sizeof(arr) / sizeof(arr[0]);
		unsigned int col = sizeof(arr[0]) / sizeof(arr[0][0]);   //把row,col拉進來就是為了每次再來是更新一次
		//長寬,因為下面我們就是用row,col變量沒有用其他變量
		printf("請輸入你想要找的數:>");
		scanf("%d", &num);
		if (search(arr, num, &row, &col))//把長寬傳地址過去用指針prow,pcol接收
		{
			printf("有這個數\n");
			printf("坐標為(%d,%d)\n", row, col);
		}
		else
		{
			printf("沒有這個數\n");
		}
	}	
	return 0;
}

C語言面試C++二維數組中的查找示例

動態基點操作

暴力操作肯定拿不下面試官的心,沒有思想,應該優化程序,減小時間復雜度

C語言面試C++二維數組中的查找示例

C語言面試C++二維數組中的查找示例

C語言面試C++二維數組中的查找示例

然后把上面search函數改改就可以了

時間復雜度也降為O(n)

#include<stdio.h>
//const 就是因為二維數組是定死的
int search(const int arr[4][4], int num,unsigned int* prow,unsigned int* pcol)
{
	int i = 0;
	unsigned int x = 0;
	unsigned int y = *pcol-1;
	while ((x<*prow)&&(y>=0))
	{
		if (arr[x][y] - num > 0)
		{
			y--;
		}
		else if (arr[x][y] - num < 0)
		{
			x++;
		}
		else
		{
			*prow = x;
			*pcol = y;
			return 1;
		}
	}
	return 0;
}
int main()
{
	int arr[4][4] = { {1,2,8,9},{2,4,9,12},{4,7,10,13},{6,8,11,15} };
	int num = 0;
	while (1)
	{
		unsigned int row = sizeof(arr) / sizeof(arr[0]);
		unsigned int col = sizeof(arr[0]) / sizeof(arr[0][0]);   //把row,col拉進來就是為了每次再來是更新一次
		//長寬,因為下面我們就是用row,col變量沒有用其他變量
		printf("請輸入你想要找的數:>");
		scanf("%d", &num);
		if (search(arr, num, &row, &col))//把長寬傳地址過去用指針prow,pcol接收
		{
			printf("有這個數\n");
			printf("坐標為(%d,%d)\n", row, col);
		}
		else
		{
			printf("沒有這個數\n");
		}
	}	
	return 0;
}

C語言面試C++二維數組中的查找示例

結果也是不錯的

以上就是C語言面試C++二維數組中的查找示例的詳細內容,更多關于C++二維數組中的查找的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/diandengren/article/details/120226553

延伸 · 閱讀

精彩推薦
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
主站蜘蛛池模板: 日产乱码2021永久手机版 | 国产盗摄女厕美女嘘嘘 | 欧美另类杂交a | 久久99精品久久久久久园产越南 | 火影忍者羞羞 | 色哟呦 | 国产乱人乱精一区二区视频密 | 4hu影院在线观看 | 超级碰在线视频 | 亚洲成年人在线观看 | 亚洲精品综合一二三区在线 | 国产一区二区三区欧美 | 大胆人gogo888体艺术在线 | 成人啪精品视频免费网站 | 波多野结衣在线观看中文字幕 | 91制片厂制作传媒破解版免费 | 韩国美女豪爽一级毛片 | yellow片在线观看 | 日韩欧美亚洲每日更新网 | 久久88综合 | 红杏劫| 国内精品国语自产拍在线观看55 | 日本一区二区三区视频在线观看 | 青草悠悠视频在线观看 | 欧美怡红院视频一区二区三区 | 久久久精品免费视频 | 18videossex性欧美69 | 91私密保健女子养生spa | 沉沦艳妇杨幂肉体小说 | 国产精品区一区二区免费 | 午夜办公室 | 九九精品免视频国产成人 | 四虎影视在线看免费 720p | 免费一级特黄特色大片∵黄 | jiizz亚洲护士厕所 | 动漫美女被褥吸奶漫画漫画 | 国产剧情一区二区三区 | 成人午夜爽爽爽免费视频 | 免费在线观看亚洲 | 欧美午夜性春猛交bbb | 日本不卡视频免费的 |