当前位置: 首页 > news >正文

文书写作网站百度竞价广告收费标准

文书写作网站,百度竞价广告收费标准,网站建设接单平台,爱做网站二维数组中的查找_牛客题霸_牛客网 (nowcoder.com) 暴力查找法: 是一种简单直接的解决方法,可以用于在二维数组中查找目标值。该方法的思路是遍历数组的每个元素,逐个与目标值进行比较。 具体步骤如下: 从数组的第一行第一列开始,…

二维数组中的查找_牛客题霸_牛客网 (nowcoder.com)

暴力查找法:

是一种简单直接的解决方法,可以用于在二维数组中查找目标值。该方法的思路是遍历数组的每个元素,逐个与目标值进行比较。

具体步骤如下:

  1. 从数组的第一行第一列开始,逐行逐列地遍历数组的每个元素。
  2. 对于当前遍历到的元素,与目标值进行比较:
    • 如果当前元素等于目标值,则找到目标值,返回true。
    • 如果当前元素大于目标值,则可以提前结束查找,因为数组已经按递增顺序排列,后续元素必定更大。
  3. 如果遍历完整个数组都没有找到目标值,则说明目标值不存在于数组中,返回false。
  4.  时间复杂度为O(m * n)
bool searchMatrix(vector<vector<int>>& matrix, int target) {for (int i = 0; i < matrix.size(); i++) {for (int j = 0; j < matrix[i].size(); j++) {if (matrix[i][j] == target) {return true;  // 找到目标值} else if (matrix[i][j] > target) {return false;  // 提前结束查找}}}return false;  // 目标值不存在于数组中
}

 

对于有序的二维数组,我们可以利用二分查找法进行查找目标值。

算法步骤:
1. 初始化指针,将左上角的元素作为起始点,将右下角的元素作为终止点。初始时,起始点为数组的左上角元素,终止点为数组的右下角元素。
2. 在每一次迭代中,将搜索区域一分为二,找到中间元素(可以选择行中间或列中间的元素)。
3. 将目标值与中间元素进行比较:
   - 如果中间元素等于目标值,则找到目标值,返回true。
   - 如果中间元素大于目标值,则目标值可能在中间元素的左侧或上方,将搜索区域缩小为左上方的子区域,即终止点变为中间元素的左上方元素。
   - 如果中间元素小于目标值,则目标值可能在中间元素的右侧或下方,将搜索区域缩小为右下方的子区域,即起始点变为中间元素的右下方元素。
4. 重复执行步骤2和步骤3,直到找到目标值或搜索区域为空(起始点超过终止点)为止。
5. 如果最终搜索区域为空,说明目标值不存在于数组中,返回false。

6.时间复杂度(cols*log(rows))

bool searchMatrix(vector<vector<int>>& matrix, int target) {if (matrix.empty() || matrix[0].empty()) {return false;  // 处理空数组的情况}int rows = matrix.size();int cols = matrix[0].size();int left = 0;int right = rows * cols - 1;while (left <= right) {int mid = left + (right - left) / 2;int midValue = matrix[mid / cols][mid % cols];if (midValue == target) {return true;  // 找到目标值} else if (midValue < target) {left = mid + 1;  // 目标值可能在中间元素的右侧或下方} else {right = mid - 1;  // 目标值可能在中间元素的左侧或上方}}return false;  // 目标值不存在于数组中
}

 

题目要求在一个二维数组中查找是否存在某个整数。该二维数组的特点是每一行从左到右递增,每一列从上到下递增。

解决该问题的一个思路是从二维数组的右上角开始比较,根据目标值与当前元素的大小关系,可以逐步缩小查找范围。具体步骤如下:

  1. 初始化指针row为0,指向第一行的最后一个元素,指针col为二维数组的列数减1,指向最后一列的第一个元素。
  2. 进入循环,比较当前指针指向的元素array[row][col]与目标值target的大小关系:
    • 如果array[row][col]等于target,说明找到了目标值,返回True
    • 如果array[row][col]大于target,说明目标值可能在当前元素的左侧,将指针col向左移动一列。
    • 如果array[row][col]小于target,说明目标值可能在当前元素的下方,将指针row向下移动一行。
  3. 如果指针rowcol超出了二维数组的边界,则说明查找范围已经越界,目标值不存在于二维数组中,返回False
  4. 空间复杂度O(m+n)
#include <iostream>
#include <vector>using namespace std;bool findTarget(vector<vector<int>>& array, int target) {if (array.empty() || array[0].empty()) {return false;}int rows = array.size();int cols = array[0].size();int row = 0;int col = cols - 1;while (row < rows && col >= 0) {if (array[row][col] == target) {return true;} else if (array[row][col] > target) {col--;} else {row++;}}return false;
}int main() {vector<vector<int>> array = {{1, 2, 8, 9},{2, 4, 9, 12},{4, 7, 10, 13},{6, 8, 11, 15}};int target1 = 7;int target2 = 3;cout << boolalpha << findTarget(array, target1) << endl;  // 输出: truecout << boolalpha << findTarget(array, target2) << endl;  // 输出: falsereturn 0;
}

http://www.mnyf.cn/news/45787.html

相关文章:

  • 微网站建设公司网络推广具体内容
  • 深圳企业注销流程优化推广方案
  • 桂林 网站建设网站推广软件ky99
  • wordpress对比discuz厦门关键词优化seo
  • 免费b2b网站要怎么做最佳的资源搜索引擎
  • 武汉580做网站谷歌浏览器手机版下载
  • 做外贸网站好还是内贸网站好媒体发稿平台
  • 宝应123网站建设网优化大师的功能有哪些
  • 医疗机械网站怎么做百度指数排名
  • 有移动端网站 怎么做app怎么做公司网站
  • 加盟招商推广网站怎么做产品推广和宣传
  • 网站建设案例 优帮云做网站怎么赚钱
  • 网站建设公司怎么办纯注册app拉新平台
  • 网站做权重有用吗成都百度推广排名优化
  • 做网站一定要买主机吗网站建设营销推广
  • php网站建设流程百度手机助手app下载官网
  • 最便宜的网站建设试分析网站推广和优化的原因
  • 怎样做网站快手刷粉娄底地seo
  • 绥化市建设局网站软文例文 经典软文范例
  • wordpress文章 插件首页关键词优化价格
  • 西安专业做网站的公司有哪些网络营销的三大基础
  • 婚礼策划网站设计百度图片搜索引擎
  • 门户网站如何做谷歌seo上海哪家优化公司好
  • 网站开发 0755百度推广渠道
  • asp.net窗体网站盘古百晋广告营销是干嘛
  • 设计师可以做兼职的网站有哪些重庆seo扣费
  • 新闻网站伪原创同义词杭州全网推广
  • 新手建站论坛免费自学电商教程
  • 济南长清网站建设今日十大头条新闻
  • 网站设计色板全国疫情最新情况公布