2013-03-17 170 views
0

我初学编程的,并试图获得此代码的工作:需要帮助的这个C++代码

#include <iostream> 
#include <vector> 
using namespace std; 
template <typename T> 
T min(vector<T>vec) { 
    T x=vec[0]; 
    int index; 
    for (int i=0; i<vec.size(); i++) { 
     if (vec[i]<x) { x=vec[i]; index=i; } 
    } 
    return index; 
} 
template <typename T> 
void printVec (vector<T>v) { 
    for (int i=0; i<v.size(); i++) 
     cout<<v[i]<<endl; 
} 
template <typename T> 
void selectSort(vector<T>&first) { 
vector<T>second; 
while(first.size()!=0) { 
    second.push_back(first[min(first)]); 
    first.erase(first.begin()+min(first)); 
    } 
     first=second; 
} 


int main() { 
    int Mas[] = { 7, 15, 14, 12, 99, 180, 197, 567, 123, -101, 32, 144, 156, 177, 4, -17, -88, 18, 99, 143, -90 }; 
    int dim = sizeof(Mas)/sizeof(int); 
    vector<int>v (&Mas[0], &Mas[dim]); 
    int m=min(v); 
    selectSort(v); 
    printVec(v); 

    cin.get(); 
    return 0; } 

出于某种原因,

while(first.size()!=0) { 

循环似乎并没有工作。 有人可以帮忙吗? 对不起,我的英语不好。

+0

你有没有试过调试它,看看哪里不行? – 2013-03-17 11:01:21

+2

你应该把代码放在这里而不是pastebin,如果你的问题得到了回答,并且pastebin中的代码稍后被取下,这个帖子对未来的用户来说是完全没有用的。 – 2013-03-17 11:02:44

+0

对不起,但我不知道如何发布整个代码。 – 2013-03-17 11:04:56

回答

2

min中,变量index未被初始化。

当向量中的第一个元素是最小的元素时,这将导致min返回一个随机垃圾值。

初始化为0(这是您的默认最小值的索引)。

当编译器警告您代码存在问题时,即使在运行该程序之前,您应该先解决该问题。

+0

谢谢,它工作! – 2013-03-17 11:26:53