程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> iostream-C++ 使用sort()函數 出現segmentation fault

iostream-C++ 使用sort()函數 出現segmentation fault

編輯:編程解疑
C++ 使用sort()函數 出現segmentation fault
 #include <iostream>
#include <algorithm>
using namespace std;
int main()
{
    int n,m,k;
    int set=1;
    int *ptr=nullptr;
    int nm;
    int i;
    while(cin>>n>>m>>k)
    {
        if(n<1||n>10||
           m<1||m>100||
           k<1||k>n*m)
            return 0;
        nm=n*m;
        ptr=new int[nm];
        int *traver=ptr;
        i=0;
        while(nm--)
        {
            cin>>ptr[i];
            ++i;

        }
        sort(ptr,ptr+nm);
        traver=ptr;
        for(int i=1;i<k;++i)
            ++traver;
        cout<<"Scenario #"<<set<<endl;
        cout<<*traver<<endl;
        ++set;
        delete [] ptr;
    }
    return 0;
}

最佳回答:


你的sort函數有問題,你前面已經經過了while(nm--)的循環,所以到了sort(ptr,ptr+nm);這句以後
nm已經是-1了

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved