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

深圳网页制作培训课程价格c盘优化大师

深圳网页制作培训课程价格,c盘优化大师,手机优化软件哪个好,西城企业网站建设文章目录 Tag题目来源题目解读解题思路方法一:枚举比较法方法二:集合的位运算表示法 写在最后 Tag 【贪心】【位运算】【数组】 题目来源 2605. 从两个数字数组里生成最小数字 题目解读 给定两个各自只包含数字 1 到 9 的两个数组,每个数组…

文章目录

  • Tag
  • 题目来源
  • 题目解读
  • 解题思路
    • 方法一:枚举比较法
    • 方法二:集合的位运算表示法
  • 写在最后

Tag

【贪心】【位运算】【数组】


题目来源

2605. 从两个数字数组里生成最小数字


题目解读

给定两个各自只包含数字 19 的两个数组,每个数组中的元素互不相同,请你返回最小的数字,这个数字的数位至少包含两个数组中的数字。


解题思路

贪心的思想,如果两个数组有交集,则答案为交集中的最小值;否则,需要找出各个数组中的最小值,用最小值组成最小答案。

我们先来讲述最小值的计算,方法有很多,可以先升序排序(降序排序)再返回首位置元素(末位置元素),还可以直接使用 API *min_element() 来计算数组中的最小值。

计算两个数组的交集有以下两种方法:

  • 枚举比较法。
  • 集合的位运算表示法。

方法一:枚举比较法

枚举所有可能的数字组合,如果该组合中的两个数字一样,则加入到交集 section 中,如果集合 section 非空,则返回集合中的最小值。

实现代码

class Solution {
public:int minNumber(vector<int>& nums1, vector<int>& nums2) {vector<int> section;for (int i = 0; i < nums1.size(); ++i) {for (int j = 0; j < nums2.size(); ++j) {if (nums1[i] == nums2[j]) {section.push_back(nums1[i]);}}}if (!section.empty()) {return *min_element(section.begin(), section.end());}int min1 = *min_element(nums1.begin(), nums1.end());int min2 = *min_element(nums2.begin(), nums2.end());return  min(min1 * 10 + min2, min2 * 10 + min1);}
};

复杂度分析

时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn) n n n 为最大的数组长度。

空间复杂度: O ( n l o g n ) O(nlogn) O(nlogn)

方法二:集合的位运算表示法

两个数组可以看作是两个集合,集合可以用二进制来表示,比如集合 S = { 1 , 2 , 3 } S = \{1, 2, 3\} S={1,2,3} 用二进制 1110 来表示,二进制数从右往左数的第 num 位为 1 表示数字 num 在集合中。

于是数组的交集就可以使用集合的交集来表示,交集可以用二进制的与操作计算,然后与操作得到的二进制数从右到左找到第一个 1 的位置,即为两个数组交集中的最小值,这里我们可以使用 __builtin_ctz() 来查找从右至左第一个 1 出现的位置。

关于集合用运算来表示,如果还有不明白的地方可以参考 位运算基础与应用 这篇文章。

实现代码

class Solution {
public:int minNumber(vector<int>& nums1, vector<int>& nums2) {// 位运算int mask1 = 0, mask2 = 0;for (int x : nums1) mask1 |= 1 << x;for (int x : nums2) mask2 |= 1 << x;int mask = mask1 & mask2;if (mask) return __builtin_ctz(mask);int x = __builtin_ctz(mask1), y = __builtin_ctz(mask2);return min(x * 10 + y, 10 * y + x);}
};

复杂度分析

时间复杂度: O ( n + m ) O(n+m) O(n+m),其中 n n n 为数组 nums1 的长度, m m m 为数组 nums2 的长度。

空间复杂度: O ( 1 ) O(1) O(1),仅使用了几个额外的变量。


写在最后

以上就是本篇文章的内容了,感谢您的阅读。🍗🍗🍗

如果感到有所收获的话可以给博主点一个 👍 哦。

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出。💬💬💬

http://www.fp688.cn/news/144386.html

相关文章:

  • 企业网站建设机构网络营销和传统营销的区别和联系
  • 做私服网站要多大空间什么搜索引擎搜索最全
  • 做网站书seo商学院
  • 网站收录提交入口怎么做西安百度快速排名提升
  • 自己给网站做优化怎么做百度搜索推广操作简要流程
  • 公司网站开发流程太原seo关键词优化
  • wordpress301不能用seo规范培训
  • 域名查询权威网站seo关键词优化培训班
  • 做网站什么前端框架方便廊坊快速排名优化
  • web程序设计与实践做网站网站推广营销运营方式
  • 二手网站建设媒体:多地新增感染趋势回落
  • 网站描述更改精准的搜索引擎优化
  • 查询公司的网站备案信息查询站长工具平台
  • 怎样创建网站教程海淀搜索引擎优化seo
  • 支付宝手机网站支付二维码怎么做新闻联播直播 今天
  • 金融理财网站建设方案网络营销推广公司有哪些
  • 网站开发团队奖惩搜索引擎营销题库和答案
  • 湘潭网站建设 就问磐石网络专业关键词优化策略有哪些
  • 软件系统定制开发洛阳seo博客
  • 怎么在网站上做排名广州网站优化
  • 北京网络建站模板推广方案是什么
  • 热点新闻事件真实事件郑州seo外包费用
  • 锡盟建设局网站网站排名优化+o+m
  • 新吴区推荐做网站电话亚马逊关键词搜索器
  • 手机网站快速排名 软件网站广告调词平台
  • 江阴哪里有做网站的专业网页设计和网站制作公司
  • 湖北医院网站建设千锋教育靠谱吗
  • asp.net做网站教程社群运营的经典案例
  • 点墨网站百度知道网页版进入
  • 企业官网建站联系我们百度云app