sort函数居然能改变元素值?记一次有趣的Bug——四数之和
坐标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——四数之和的更多相关文章
- STL sort 函数实现详解
作者:fengcc 原创作品 转载请注明出处 前几天阿里电话一面,被问到STL中sort函数的实现.以前没有仔细探究过,听人说是快速排序,于是回答说用快速排序实现的,但听电话另一端面试官的声音,感觉不 ...
- STL sort 函数实现详解 ZZ
前几天阿里电话一面,被问到STL中sort函数的实现.以前没有仔细探究过,听人说是快速排序,于是回答说用快速排序实现的,但听电话另一端面试官的声音,感觉不对劲,知道自己回答错了.这几天特意看了一下,在 ...
- jquery获取、改变元素属性值
//标签的属性称作元素属性,在JS里对应的DOM对象的对应属性叫DOM属性.JS里的DOM属性名有时和原元素属性名不同. //==================================操作元 ...
- java 数据类型:集合接口Collection之List~ArrayList:remove移除;replaceAll改变原有值;sort排序;迭代器listIterator();
什么是List集合: 特点: 元素有序可重复的集合. 集合中每个元素都有其对应的顺序索引. List集合默认按元素的添加顺序设置元素的索引,索引从0开始. List接口的常用方法: List可以使 ...
- /编写一个函数,要求从给定的向量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:$ */ /* 编写一个 ...
- sort函数用法
原文链接:http://blog.csdn.net/csust_acm/article/details/7326418 sort函数的用法 做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己 ...
- Perl Sort函数用法总结和使用实例
一) sort函数用法 sort LISTsort BLOCK LISTsort SUBNAME LIST sort的用法有如上3种形式.它对LIST进行排序,并返回排序后的列表.假如忽略了SUBNA ...
- STL——sort函数简介
参考:http://blog.csdn.net/s030501408/article/details/5329477 0)与C标准库qsort的比较:http://bbs.csdn.net/topic ...
- SORT函数的使用方法(转载)
sort函数的用法(转载出处:http://blog.sina.com.cn/s/blog_6439f26f01012xw3.html) 做ACM题的时候,排序是一种经常要用到的操作.如果每次都自己写 ...
随机推荐
- C++ strcmp与strncmp的比较
C++ strcmp与strncmp的比较(转载) 原文链接:https://www.cnblogs.com/ybqjymy/p/12565444.html strcmp与strncmp都是用来比较 ...
- Qt 绘图(QBitmap,QPixmap,QImage,QPicture)
QPainter绘图绘图设备(QPixmap,QImage,QBitmap,QPicture) 重写绘图事件,虚函数 如果窗口绘图,必须放在绘图事件里实现 绘图事件内部自动调用,窗口需要重绘的时候,状 ...
- 3个必备cookie实用方法
今天跟大家介绍一下三种cookie的使用方法,selenium提供了我们add_cookie()方法来跳过验证码直接登录的方法.我们现在以博客园登录为例,都知道现在博客园登录要拼图验证. 先在网页打开 ...
- Google Analytics谷歌分析事件之非互动事件
非互动事件官方的解释如下 “非互动”一词是指可选的布尔值参数,此参数可以传递到用于发送事件命中的方法.通过此参数,您可以确定要如何为网站上包含事件衡量的网页定义跳出率.例如,假设您的首页上内嵌有一个视 ...
- Codeforces1409 题解(A-F)
A. Yet Another Two Integers Problem 最优的操作中,\(k = \min(10, abs(a - b))\),记\(d=abs(a-b)\),最终的答案为\(ans ...
- JDK15就要来了,你却还不知道JDK8的新特性!
微信搜「烟雨星空」,白嫖更多好文. 现在 Oracle 官方每隔半年就会出一个 JDK 新版本.按时间来算的话,这个月就要出 JDK15 了.然而,大部分公司还是在使用 JDK7 和 8 . 之前去我 ...
- 跟着兄弟连系统学习Linux-【day07】
day07-20200604 p25.vim常用操作 vim需要经常练习,一般用于修改配置文件.
- CentOS 7 安装部署 cassandra作为kairosdb的数据存储
环境 Centos 7.4 java 1.8.0 安装步骤 java yum -y install java-1.8.0-openjdk* cassandra wget https://mirrors ...
- leetcode刷题-82.删除排序链表中的重复元素 II
题目 给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字. 示例 1: 输入: 1->2->3->3->4->4->5输出: 1- ...
- 11.redis cluster的hash slot算法和一致性 hash 算法、普通hash算法的介绍
分布式寻址算法 hash 算法(大量缓存重建) 一致性 hash 算法(自动缓存迁移)+ 虚拟节点(自动负载均衡) redis cluster 的 hash slot 算法 一.hash 算法 来了一 ...