首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C++插入排序崩溃

C++插入排序崩溃
EN

Stack Overflow用户
提问于 2014-11-19 05:23:37
回答 2查看 68关注 0票数 1

我创建了一个向量,并用随机整数填充它。然后,我打印出所有未排序的值并调用insertionSort()。在此调用之后,应按排序顺序打印数字。我的程序总是崩溃,我不知道为什么。

下面是我的代码:

代码语言:javascript
复制
#include <cstdlib>
#include <iostream>
#include <vector>
#include <time.h>

using namespace std;

int listSize;

vector<int> intList()
{
    cout << "How many numbers do you want to sort?\n";
    cin >> listSize;
    vector<int> list;
    for (int i = 0; i < listSize; i++)
    {
        int random = rand() % 10001;
        list.push_back(random);
    }

    return list;
};

void insertionSort(vector<int>& data)
{
    int i, j, tmp;

    for (i = 1; data.size(); i++)
    {
        j = i;
        tmp = data[i];
        while (j > 0 && tmp < data[j-1])
        {
            data[j] = data[j-1];
            j--;
        }
        data[j] = tmp;
    }
}

int main(int argc, char** argv)
{
    srand(time(0));
    vector<int> list = intList();
    for (vector<int>::iterator it = list.begin(); it != list.end(); it++)
    {
        cout << *it << " ";
    }
    cout << "\n";

    insertionSort(list);

    for (vector<int>::iterator it = list.begin(); it != list.end(); it++)
    {
        cout << *it << " ";
    }

}
EN

回答 2

Stack Overflow用户

发布于 2014-11-19 05:25:11

代码语言:javascript
复制
for (i = 1; data.size(); i++)

应该是:

代码语言:javascript
复制
for (i = 1; i<data.size(); ++i)

否则,for永远不会中断。

票数 5
EN

Stack Overflow用户

发布于 2014-11-19 05:26:06

你的for循环不检查中断条件,并且循环总是开始写出边界。

代码语言:javascript
复制
for (i = 1; data.size(); i++)

您应该检查i是否小于向量的大小。

代码语言:javascript
复制
for (i = 1; i < data.size(); i++)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27004321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档