继上次家里介绍的 相亲对象失败 以后,家里热心的亲戚又给本大龄单身猿介绍了一个妹子,不,或许应该叫姐姐,她比我大三岁。俗话说 “女大三抱金砖” ,本着 “试试看不行就当朋友” 的心态我们就加上了微信。
刚开始聊的还算可以,毕竟大家刚认识,来来回回都是一些比较拘谨客套的话题。到这里还都算比较正常。
本以为她比我年纪大一点,而且是销售,可能性格上和待人接物上都会是比较 成熟温柔体贴 的大姐姐类型,没想到随着认识时间的增加,以及聊天话题的深入,慢慢显露出了一些问题。。。
在我看来的缺点
口头禅 —— 不走心
在认识的初期,我从来没主动和她提过要照片或者视频之类的要求(因为我知道这点经常被女生吐槽诟病),但是她却频繁向我索取,我说可以啊,那公平起见,我们就双方互换 —— 我发一张生活照,你也发一张生活照。谁知她却说我连这点小小要求都无法做到,实在是 “不走心” 。。。。
此后还有让发语音听听声音、询问体重之类的要求,甚至还问起我小时候的一些比较 隐私 成长经历,我有些实在不想作答,最后也都是以 “不走心” 而被打上标签。
虽然自己不会做饭,但是要求对方会
我虽然平时会喜欢看看美食教学频道,但是也只是偶尔的心血来潮,没有那么高的厨艺水平(可能随着时间的磨炼会逐渐提升),而且我也希望是两个人能够一起在厨房张罗,而不是只有我一个人在忙活,哪怕只是打打下手(当然最好是能教教我、带带我)。
喜欢给别人打分
此外,她还喜欢给别人打分。。。稍有不顺她的意思,她的另外一句口头禅就是 “减分” 。
不知道和她以前是管理层有没有关系,我曾经开玩笑试探性的问过她是不是 “妻管严” 的那种 “严妻” ,她回答 “是的”。所以和她聊天的过程中,时不时就有一种被班主任 “居高临下” 训斥的感觉。
最近的一次,就是因为我忘记了她曾经和我说过她的星座,然后我又问了一遍,结果又被 “减分” 了 。。。
有近乎夸张的洁癖
她和我说过她有一定的洁癖,我本来不以为然,因为大多数女生都是爱干净的。但是有一次她和我提起了一件事,我觉得着实有些夸张:某天她在和同事开会,在此期间,她的一个男性同事随手拿了她放在桌上的手机看了几眼,结果她就心中十分的 “膈应”、万般恶心,等到会议结束以后,她就匆匆去拿酒精把手机消毒了一遍。。。
在我看来的优点
当然她也有一些优点的,比如她同情弱势群体,之前某地有个卖牛肉的售货员因为制止某个女顾客(据说是位女老师)把吃了一半的牛肉放回去,而被那位女顾客推搡谩骂,她就十分的义愤填膺,并说起她曾经也因为公司里的一些工作人员对保洁大叔不礼貌,而仗义执言的事迹。
此外,作为职场上经验丰富的 “老手”,见过各种领导和老板,她还热心指导过我一些职场关于上下级关系处理方面的知识与窍门。
但是很遗憾的是,我们之间还是没有擦除爱情的火花,可能是因为年龄差距而导致的代沟?幽默感有时不太一样,我的一些笑点她
get() 不到,她的一些笑点我也 get() 不到。然后再涉及到一些比较高层次的政经文学等话题的探讨,更是接不住对方的梗,所以发展到今天 “被拉黑” 也并不意外。
虽然我被拉黑了,但是我又又又从这次 “失败” 里悟出了 一个道理 ——
两个人其实就像两个独立的链表。
合不合适、能否 Merge 在一起,是需要将各个“结点”(三观、性格、爱好)逐一进行比较,然后试图“排序”的。 但现实与算法最大的不同点在于: 两个链表的合并算法总会返回一个 Head; 而人与人的结合,可能在某个“结点”磨合失败时,就直接触发了 Break,随即分道扬镳,返回 Null。
带着这份遗憾和感悟,我写下了这份代码和注释
/**
* @brief 合并两个有序链表(也是两个人的磨合隐喻)
*
* @param l1 第一个链表(小雅的特质链)
* @param l2 第二个链表(小明的特质链)
* @return pair<ListNode*, ListNode*> (合并后的头, 尾)
*
* 🎭 算法 vs 人生对比:
* ┌─────────────────────────────────────────┐
* │ 算法:while(l1 && l2) 必定完成 │
* │ 人生:while(相处) 可能提前break │
* └─────────────────────────────────────────┘
*/
pair<ListNode*, ListNode*> merge(ListNode* l1, ListNode* l2) {
// 🏁 创建虚拟头节点(类比:媒人/初次见面的契机)
ListNode dummy(0);
ListNode* tail = &dummy; // tail:当前已磨合到的位置
// 🔄 核心循环:只要双方都还有特质待比较
// 💔 现实中可能在此处提前break(某个节点无法妥协)
while (l1 && l2) {
// ⚖️ 比较当前特质的优先级
// val越小 = 越愿意在这个方面妥协
if (l1->val > l2->val) {
swap(l1, l2); // 🔄 确保l1是更愿意让步的一方
}
// ✅ 将l1的当前特质作为共识,连接到结果链表
// (隐喻:达成一个妥协)
tail->next = l1;
// ⏩ l1后移:继续看下一个特质
l1 = l1->next;
// 🏁 tail也后移:更新"已磨合进度"
tail = tail->next;
}
// 🎁 善后:将剩余的特质直接链上
// (隐喻:到了这一步,剩余的特质无条件接纳)
tail->next = l1 ? l1 : l2;
// 📍 让tail指向最终的尾部
while (tail->next) {
tail = tail->next;
}
// 💍 返回合并后的"关系":(起点, 终点)
return {dummy.next, tail};
}
/**
* 💔 现实中的"提前退出"版本:
*/
pair<ListNode*, ListNode*> realWorldMerge(
ListNode* person1,
ListNode* person2,
function<bool(int,int)> isBreakpoint // 判断是否遇到不可妥协的点
) {
ListNode dummy(0);
ListNode* tail = &dummy;
while (person1 && person2) {
// ⚠️ 检查是否遇到关系破裂点
if (isBreakpoint(person1->val, person2->val)) {
// 💔 提前退出!无法继续磨合
return {nullptr, nullptr};
}
if (person1->val > person2->val) {
swap(person1, person2);
}
tail->next = person1;
person1 = person1->next;
tail = tail->next;
}
tail->next = person1 ? person1 : person2;
while (tail->next) tail = tail->next;
return {dummy.next, tail};
}
📚 代码逻辑速记表(结合情感隐喻)
| 代码片段 | 情感隐喻(记忆钩子) | 逻辑说明 |
|---|---|---|
ListNode dummy(0); | 初次见面 | 创建一个虚拟头节点,作为关系的起点。 |
ListNode* tail = &dummy; | 当前状态 | tail 始终指向两个人共同生活的“当下”这一刻。 |
while (l1 && l2) | 相处时光 | 只要两个人都在场,生活就要继续(循环比较)。 |
if (l1->val > l2->val) | 发生分歧 | 当 L1 的“自我”太大,或者 L2 的更合适时。 |
swap(l1, l2); | 学会妥协 | 关键点! 代码中为了方便,始终让 l1 作为较小(优先)的那一个。在感情里,这意味着**“这次听你的”**。 |
tail->next = l1; | 接纳对方 | 将“妥协后”的那个节点,接入共同的生活轨迹。 |
tail = tail->next; | 携手前行 | 指针后移,时间向前推移,准备迎接下一个挑战。 |
return {dummy.next, tail}; | 最终结局 | 返回这段关系的起点(回忆)和终点(现状)。 |
收尾
或许这份遗憾能够加深对链表合并算法的印象吧
谢谢您!