首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

C++二分查找算法:132 模式解法二枚举2

  • 23-11-18 17:43
  • 4508
  • 11625
blog.csdn.net

本题不同解法

包括题目及代码C++二分查找算法:132 模式解法一枚举3
C++二分查找算法:132 模式解法二枚举2
代码最简洁C++二分查找算法:132 模式解法三枚举1
性能最佳C++单调向量算法:132 模式解法三枚举1

分析

第一步,选择各3对应的1,如果有多个符合对应最小的1,记录num[0,j)中的最小值iMin,如果nums[j]大于iMin,则m3To1 [nums[j]] = iMin,否则等于一个不存在的大数,比如:100010001000+1。
第二步,枚举2,m31的key是3的值,value是1的值,寻找key大于nums[k]中,是否存在value小于nums[k]。如果key1 >= key0,且value1 <= value0。如果k0大于nums[k],则k1一定大于nums[k],如果value0小于nums[k],则vaule1也小于nums[k]。故key1淘汰了key0。淘汰后,key和value都是按升序排序。第一个大于nums[k]的key,对应的value最小,如果此value不小于nums[k],则其它value更不符合。
先要判断是否被旧值淘汰,再看是否淘汰旧值。

核心代码

class Solution{
public:
bool find132pattern(vector&nums) {
m_c = nums.size();
const int iNotMayMaxValue = 1000 * 1000 * 1000 + 1;
{
int iMin = iNotMayMaxValue;
for (int j = 0; j < m_c; j++)
{
m3To1[nums[j]] = (nums[j] > iMin) ? iMin:iNotMayMaxValue;
iMin = min(iMin, nums[j]);
}
}
//寻找2,即nums[k]
{
std::map m31;
for (int k = 0; k < m_c; k++)
{
const int& iValue = nums[k];
auto it = m31.upper_bound(iValue);
if (m31.end() != it)
{
if (it->second < nums[k])
{
m_iIndex2 = k;
return true;
}
}
it = m31.lower_bound(iValue);
const int iOne = m3To1[nums[k]];
if ((m31.end()!=it)&&(it->second <= iOne))
{
continue;//被旧值淘汰
}
auto ij = it;
while( it != m31.begin())
{
–it;
if (it->second >= iOne)
{
it = m31.erase(it);
}
}
m31[iValue] = iOne;
}
}
return false;
}
std::unordered_map m3To1;
int m_iIndex2 = -1;
int m_c;
};

测试用例

template
void Assert(const T& t1, const T& t2)
{
assert(t1 == t2);
}

template
void Assert(const vector& v1, const vector& v2)
{
if (v1.size() != v2.size())
{
assert(false);
return;
}
for (int i = 0; i < v1.size(); i++)
{
Assert(v1[i], v2[i]);
}
}

int main()
{
vector nums;
bool res;
{
Solution slu;
nums = { 3,5,0,3,4 };
res = slu.find132pattern(nums);
//Assert(vector{5, 0, 5, 2, 0}, slu.m_v3To1);
Assert(4, slu.m_iIndex2);
Assert(true, res);
}
{
nums = { 1 ,2, 3,4 };
res = Solution().find132pattern(nums);
Assert(false, res);
}
{
Solution slu;
nums = { 3,1,4,2 };
res = slu.find132pattern(nums);
//Assert(vector{4, 4, 0, 1}, slu.m_v3To1);
Assert(3, slu.m_iIndex2);
Assert(true, res);
}
{
Solution slu;
nums = { -1,3,2,0 };
res = slu.find132pattern(nums);
//Assert(vector{4, 0, 0, 0}, slu.m_v3To1);
Assert(2, slu.m_iIndex2);
Assert(true, res);
}

//CConsole::Out(res);
  • 1

}

扩展阅读

视频课程

有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快

速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关下载

想高屋建瓴的学习算法,请下载《闻缺陷则喜算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653

洒家想对大家说的话
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
墨家名称的来源:有所得以墨记之。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境:

VS2022 C++17

群中有博文配套源码
QQ群名片
注:本文转载自blog.csdn.net的闻缺陷则喜何志丹的文章"https://blog.csdn.net/he_zhidan/article/details/134426639"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

101
推荐
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top