坐标leetcode:

  

  我想都不想直接深度优先搜索暴力求解:

class Solution {
public:
vector<vector<int>> res; //答案
int sum =0; //temp中的总和
vector<int> temp;//用于存储一个解 bool check(vector<int>&a,vector<int> &b)//用于判断两个解是否相同(因为res中已经排序所以直接比较 很方便)
{
for(int i = 0;i<4;i++)
{
if(a[i]!=b[i])
return false;
}
return true;
} void dfs(vector<int>&nums,int sub,int target)//sub为当前下标
{
if(temp.size()==4)
{
if(sum == target)
{
for(int i =0;i<res.size();++i) //判断重复 若重复则不加入此解
{
if(check(res[i],temp))
return;
}
sort(temp.begin(),temp.end());
res.push_back(temp);
}
return;
}
if(sub>=nums.size())
return ; //存入当前下标的元素
sum+=nums[sub];
temp.push_back(nums[sub]);
dfs(nums,sub+1,target);
//不存入当前下标的元素
sum-=nums[sub];
temp.erase(temp.end()-1);
dfs(nums,sub+1,target); }
vector<vector<int>> fourSum(vector<int>& nums, int target) {
dfs(nums,0,target);
return res;
}
};

  我自信地按下了提交按钮,结果连示例都没过得了!!?

  而且结果很让人问号:

这···怎么会出现[-2,-1,-1,2]这个解??

于是我把sort注释掉  把判重也注释掉:

class Solution {
public:
vector<vector<int>> res; //答案
int sum =0; //temp中的总和
vector<int> temp;//用于存储一个解 bool check(vector<int>&a,vector<int> &b)//用于判断两个解是否相同(因为res中已经排序所以直接比较 很方便)
{
for(int i = 0;i<4;i++)
{
if(a[i]!=b[i])
return false;
}
return true;
} void dfs(vector<int>&nums,int sub,int target)//sub为当前下标
{
if(temp.size()==4)
{
if(sum == target)
{
                 //sort(temp.begin(),temp.end());
          //for(int i =0;i<res.size();++i)      //判断重复 若重复则不加入此解
//{
// if(check(res[i],temp))
// return;
// } res.push_back(temp);
}
return;
}
if(sub>=nums.size())
return ; //存入当前下标的元素
sum+=nums[sub];
temp.push_back(nums[sub]);
dfs(nums,sub+1,target);
//不存入当前下标的元素
sum-=nums[sub];
temp.erase(temp.end()-1);
dfs(nums,sub+1,target); }
vector<vector<int>> fourSum(vector<int>& nums, int target) {
dfs(nums,0,target);
return res;
}
};

好的,结果惊了,就是正确答案:

于是我开vs复原了这题的解,同样是这个奇怪的结果。

这···难道sort改变了元素值的大小???

然后我单独试验了sort函数,发现函数并没有问题。

那么问题来了。。。。。。Bug出在哪里?为什么会出现sort函数改变了元素值的假象?

于是我开始了不同的尝试探索问题的原因。

一、改变记录sum的方法

  我将全局变量sum去掉,改为需要的时候当场对temp求和。

按道理,结果应该不会改变,但是却改变了。[-2,-1,-1,2]这个解变为了[-1,-1,0,2]。

这说明dfs的执行逻辑出现了问题。

二、用大脑运行程序

这果然是个好办法!。。。

我从头到尾思考了很多遍,感觉逻辑没问题啊。

于是我又从头到尾思考了很多遍,

终  于  知  道  bug  到  底  在  哪  里  了  !

这一切都是因为全局变量temp!

我以为temp.erase(temp.end()-1)就能够把刚才加入的元素给弹掉。。

结果并不是!!因为temp已经排序过了!!!最后一个元素不是在这个递归层加进去的那个元素!!!

       vector<int> ttemp = temp;
sort(ttemp.begin(), ttemp.end());

        for(int i =0;i<res.size();++i)
        {
          if(check(res[i],ttemp))
          return;
        }

            res.push_back(ttemp);

哈!哈!哈!这样总算能过吧!这代码已经绝!对!不!会!有!b!u!g!了!哈!哈!哈!

退役了再见

sort函数居然能改变元素值?记一次有趣的Bug——四数之和的更多相关文章

  1. STL sort 函数实现详解

    作者:fengcc 原创作品 转载请注明出处 前几天阿里电话一面,被问到STL中sort函数的实现.以前没有仔细探究过,听人说是快速排序,于是回答说用快速排序实现的,但听电话另一端面试官的声音,感觉不 ...

  2. STL sort 函数实现详解 ZZ

    前几天阿里电话一面,被问到STL中sort函数的实现.以前没有仔细探究过,听人说是快速排序,于是回答说用快速排序实现的,但听电话另一端面试官的声音,感觉不对劲,知道自己回答错了.这几天特意看了一下,在 ...

  3. jquery获取、改变元素属性值

    //标签的属性称作元素属性,在JS里对应的DOM对象的对应属性叫DOM属性.JS里的DOM属性名有时和原元素属性名不同. //==================================操作元 ...

  4. java 数据类型:集合接口Collection之List~ArrayList:remove移除;replaceAll改变原有值;sort排序;迭代器listIterator();

    什么是List集合: 特点: 元素有序可重复的集合. 集合中每个元素都有其对应的顺序索引. List集合默认按元素的添加顺序设置元素的索引,索引从0开始.   List接口的常用方法: List可以使 ...

  5. /编写一个函数,要求从给定的向量A中删除元素值在x到y之间的所有元素(向量要求各个元素之间不能有间断), 函数原型为int del(int A ,int n , int x , int y),其中n为输入向量的维数,返回值为删除元素后的维数

    /** * @author:(LiberHome) * @date:Created in 2019/2/28 19:39 * @description: * @version:$ */ /* 编写一个 ...

  6. sort函数用法

    原文链接:http://blog.csdn.net/csust_acm/article/details/7326418 sort函数的用法 做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己 ...

  7. Perl Sort函数用法总结和使用实例

    一) sort函数用法 sort LISTsort BLOCK LISTsort SUBNAME LIST sort的用法有如上3种形式.它对LIST进行排序,并返回排序后的列表.假如忽略了SUBNA ...

  8. STL——sort函数简介

    参考:http://blog.csdn.net/s030501408/article/details/5329477 0)与C标准库qsort的比较:http://bbs.csdn.net/topic ...

  9. SORT函数的使用方法(转载)

    sort函数的用法(转载出处:http://blog.sina.com.cn/s/blog_6439f26f01012xw3.html) 做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己写 ...

随机推荐

  1. Inno Setup Compiler 中文使用教程

    一.概要 该文章主要解决,Inno Setup Compiler工具的使用问题. 如有什么建议欢迎提出,本人及时修改.[如有任何疑惑可以加Q群:580749909] 二.步骤 (1)下载地址:http ...

  2. 使用kind快速创建本地集群

    简 介 kind是另一个Kubernetes SIG项目,但它与minikube有很大区别.它可以将集群迁移到Docker容器中,这与生成虚拟机相比,启动速度大大加快.简而言之,kind是一个使用Do ...

  3. Diophantus of Alexandria(唯一分解定理)

    Diophantus of Alexandria was an Egypt mathematician living in Alexandria. He was one of the first ma ...

  4. 【Nginx】面试官:给我讲讲Nginx如何实现四层负载均衡?

    写在前面 这次又被问到Nginx四层负载均衡的问题了,别慌,我们一起来细细分析这个看似简单的问题. 如果文章对你有点帮助,请关注 冰河技术 微信公众号,点赞.在看.留言和转发,大家的四连是我持续创作的 ...

  5. 15_Web框架-mini frame

    1.WSGI协议概述(Python Web Server Gateway Interface) 1.WSGI允许开发者将选择web框架和web服务器分开,可以混合匹配web服务器和web框架,选择一个 ...

  6. 一位北漂12年IT工程师的年终总结

    Hi,我叫李振良,来自河南周口农村的一个普通家庭,如今来北京已经12年了,我是那种没有大学背景.没有聪明头脑.没有人脉的奋斗青年,但我又是那种不甘于现状,一直想做最好的那个人! 2019年已悄然离去, ...

  7. 目标检测中的IOU和CIOU原理讲解以及应用(附测试代码)

    上期讲解了目标检测中的三种数据增强的方法,这期我们讲讲目标检测中用来评估对象检测算法的IOU和CIOU的原理应用以及代码实现. 交并比IOU(Intersection over union) 在目标检 ...

  8. Python文件.py转换为.exe可执行程序,制作.exe文件图标

    当大家想要将自己写的Python程序对别人进行展示的时候,你是否还是打开你的Pycharm进行运行展示? 假如是专业的人士看你的代码,一眼就能看懂你的代码,而其实我们可以不需要给代码,利用pyinst ...

  9. 非旋Treap——维护数列

    https://www.luogu.org/problemnew/show/P3391 知识点:1.split:1.拆数值 2.拆排名 2.merge 3.截取l - r这个区间,先截l - 1出来, ...

  10. Java使用ArrayList实现“群主发红包”功能

    群主发普通红包,某群有多名成员,群主给成员发普通红包,普通红包的规则: 群主的一笔金额,从群主余额中扣除,平均分成n等份,让成员领取: 成员领取红包后,保存到成员余额中. 请根据描述,完成案例中所有类 ...