注册 登录
编程论坛 C++教室

函数模板问题,程序能运行,但是不能正常排序

jioper 发布于 2017-03-23 11:44, 1517 次点击
要求是用函数模板做比较n个数据的大小,但是我输入完了以后程序直接退出,并不排序,看了半天不知道为什么,求大神帮助
#include<iostream>
using namespace std;
template<typename T>            
T paixu(T*a,int n)                    
{
     for(int i=0;i<n;i++){              
         for(int j=0;j<n;j++){
                if(a[i]<a[j]){
                         T temp=a[i];
                         a[i]=a[j];
                         a[j]=temp;
                }
         }
     }
      for(int i=0;i<n;i++)  
          cout<<a[i]<<endl;
      return 0;
}
int main()
{
     int n;
     cout<<"输入所需数据个数"<<endl;
     cin>>n;
     int *p=new int [n];
     cout<<"输入比较的数据"<<endl;
     for(int i=0;i<n;i++)
         cin>>p[i];      
     paixu(p,n);                                 
     return 0;
}
3 回复
#2
rjsp2017-03-23 12:22
直接退出,并不排序

“并不排序”--- 你怎么知道没有排序?你说过“直接退出”,那么有没有可能是输出后立即退出了,只是你来不及看到而已?
“直接退出”--- 程序结束了,当然应该直接退出。

虽然你的排序算法是错的,但输出并没有问题。
瞎猜猜吧,你可能是按F5调试运行的,也可能是双击直接运行程序的。
若是,建议要么按CTRL+F5运行,要么在cmd.exe中运行。
#3
jioper2017-03-23 14:53
回复 2楼 rjsp
确实如您所说,谢谢啦。另外排序算法错在哪里了?您能指正一下吗?谢谢啦
#4
rjsp2017-03-23 15:27
以下是引用jioper在2017-3-23 14:53:25的发言:

确实如您所说,谢谢啦。另外排序算法错在哪里了?您能指正一下吗?谢谢啦

选择排序的比较次数应该是 n(n-1)/2 次
而你的比较次数是 n*n 次,结果虽然没错,但算法是0分还是100分就看你老师的态度了

程序代码:
template<typename T>
void mysort( T* a, size_t n )
{
    for( size_t i=0; i!=n; ++i ) {
        for( size_t j=i+1; j!=n; ++j ) {
            if( a[i] > a[j] ) {
                T temp = a[i];
                a[i] = a[j];
                a[j] = temp;
            }
        }
    }
}

1