当前位置:网站首页>情侣牵手[贪心 & 抽象]
情侣牵手[贪心 & 抽象]
2022-08-04 23:36:00 【REN_林森】
前言
贪心是考察分析能力的好题,尤其是带干扰性的,即需要我们将有用信息提取,去伪存真,将问题能够抽象出来。动态规划也是一样,如果没有抽象思维提取要害信息,则定义不出状态,自然也找不到状态如何转移。当然阅读理解题/脑筋急转弯,就更需要这种抽象有用信息的能力。
一、情侣牵手
二、贪心&抽象
package everyday.hard;
// 情侣牵手。
public class MinSwapsCouples {
/* 抽象思维:其实我们并不关心1/2/3...这些位置,我们只关心特殊的相邻关系<0,1><2,3>。 那么一对特殊位置<x,y>,有2种情况。一是情侣则不管;二不是情侣,可以换走1个人,也可换走2个人。 由于我们只关心相邻位置,即把两对情侣的男生换掉,换个角度看,其实也可看成把两个女生换掉,所以我们在乎的是相邻对,而不是特别的位置。 所以,根据贪心,换1人的做法是最好的,留下一个人,就少换一次。 */
public int minSwapsCouples(int[] row) {
int cnt = 0;
for (int i = 0; i < row.length; i += 2) {
int target = (row[i] & 1) == 0 ? row[i] + 1 : row[i] - 1;
if (target == row[i + 1]) continue;
findAndSwap(row, i + 1, target);
cnt++;
}
return cnt;
}
private void findAndSwap(int[] row, int begin, int target) {
int i = begin + 1;
while (i < row.length && target != row[i]) ++i;
row[i] = row[begin];
row[begin] = target;
}
}
总结
1)多练习贪心题,锻炼分析能力 & 信息加工能力 & 信息提取与转换能力。
参考文献
[1] LeetCode 情侣牵手
边栏推荐
猜你喜欢
堪称奔驰“理财产品”,空间媲美宝马X5,采用了非常运动的外观
3年,从3K涨薪到20k?真是麻雀啄了牛屁股 — 雀食牛逼呀
truffle
Will we still need browsers in the future?(feat. Maple words Maple language)
uniapp 分享功能-分享给朋友群聊朋友圈效果(整理)
[Cultivation of internal skills of string functions] strcpy + strcat + strcmp (1)
自从新来了个字节20K出来的,就见识到了什么是天花板
三大技巧让你成功入门3D建模,零基础小白必看
I was rejected by the leader for a salary increase, and my anger rose by 9.5K after switching jobs. This is my mental journey
【手撕AHB-APB Bridge】~ AMBA总线 之 AHB
随机推荐
【字符串函数内功修炼】strcpy + strcat + strcmp(一)
Service Mesh落地路径
【字符串函数内功修炼】strlen + strstr + strtok + strerror(三)
被领导拒绝涨薪申请,跳槽后怒涨9.5K,这是我的心路历程
再肝3天,整理了90个 NumPy 例子,不能不收藏!
仪表板展示 | DataEase看中国:数据呈现中国资本市场
C5750X7R2E105K230KA(电容器)MSP430F5249IRGCR微控制器资料
直接插入排序
生产者消费者问题
对写作的一些感悟
安全软件 Avast 与赛门铁克诺顿 NortonLifeLock 合并案获英国批准,市值暴涨 43%
Community Sharing|Tencent Overseas Games builds game security operation capabilities based on JumpServer
小黑leetcode冲浪:94. 二叉树的中序遍历
为何越来越多人选择进入软件测试行业?深度剖析软件测试的优势...
一点点读懂Thremal(二)
Literature reading ten - Detect Rumors on Twitter by Promoting Information Campaigns with Generative Adversarial Learn
基于Appian低代码平台开发一个SpaceX网站
未来我们还需要浏览器吗?(feat. 枫言枫语)
KT148A电子语音芯片ic方案适用的场景以及常见产品类型
如何根据地址获取函数名