免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1836 | 回复: 2
打印 上一主题 下一主题

[C++] 为什么程序总是跳转到vector头文件中,然后终止呢 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-10-12 20:04 |只看该作者 |倒序浏览
如下代码实现mergesort,
  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;

  4. void merge (vector<int> &arr, int first , int mid, int last, vector<int> &crr)
  5. {
  6.         int f = first;
  7.         int m = mid + 1;
  8.         int t = 0;

  9.         while (f <= mid && m <= last)
  10.         {
  11.                 if (arr[f] < arr[m])
  12.                         crr[t++] = arr[f++];
  13.                 else
  14.                         crr[t++] = arr[m++];
  15.         }

  16.         while (f <= mid)
  17.                 crr[t++] = arr[f++];
  18.         while (m <= last)
  19.                 crr[t++] = arr[m++];

  20.         for (int i = 0; i < t; ++i)
  21.                 arr[first + i] = crr[i];
  22. }
  23. void mergeSort (vector<int> &arr, int first, int last, vector<int> &crr)
  24. {
  25.         int mid = (first + last) / 2;
  26.         while (first < mid)
  27.         {
  28.                 mergeSort (arr, first, mid, crr);
  29.                 mergeSort (arr, mid + 1, last, crr);
  30.                 merge (arr, first, mid, last, crr);
  31.         }
  32. }

  33. void mergeSort (vector<int> &arr)
  34. {
  35.         vector<int> crr (arr.size());
  36.         mergeSort (arr, 0, arr.size() - 1, crr);
  37. }


  38. int main ()
  39. {
  40.         int a[] = {
  41.                 1, 10, 20, 30, 50, 2, 88, 4, 60, 100
  42.         };
  43.         vector<int> arr (a, a + 10);
  44.         mergeSort (arr);
  45.         for (vector<int>::iterator iter = arr.begin(); iter != arr.end(); ++iter)
  46.                 cout << *iter << '\t';
复制代码
gdb单步跟踪到调用 mergeSort (arr, 0, arr.size() - 1, crr);
输出如下内容
(gdb) s
std::vector<int, std::allocator<int> >::size (this=0x7fffffffe0d0)
    at /usr/lib/gcc/x86_64-redhat-linux/4.4.6/../../../../include/c++/4.4.6/bits/stl_vector.h:533
533              { return size_type(this->_M_impl._M_finish - this->_M_impl._M_start); }


论坛徽章:
0
2 [报告]
发表于 2012-10-16 14:00 |只看该作者
你这个貌似越界了吧。ps:vector<int> arr (a, a + 10);  改下,vector<int> arr (a, a + 9);

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [报告]
发表于 2012-10-16 14:54 |只看该作者
烂代码,还递归,更看不懂了。就事论事吧
while (first < mid)
        {
                mergeSort( arr, first, mid, crr );
                mergeSort( arr, mid+1, last, crr );
                merge( arr, first, mid, last, crr );
        }
看起来像个死循环
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP