这个程序哪错了 就是写一个函数将10个字符串排序 并在主函数中输出 谢谢了
#include<iostream>#include<string>constintn=10;usingnamespacestd;intmain(){stringstr[...
#include<iostream>
#include<string>
const int n=10;
using namespace std;
int main()
{string str[n];
void sort(string *,int n);
cout<<"please input ten strings:"<<endl;
for(int i=0;i<10;i++)
getline(cin,str[i]);
sort(str,n);
for(i=0;i<10;i++)
cout<<str[i]<<endl;
return 0;
}
void sort(string *p,int n)
{string s1;
int k;
for(int i=0;i<n-1;i++)
{k=i;
for(int j=i+1;j<n;j++)
{if(*(p+k)>*(p+j))
{k=j;
s1=*(p+k);
*(p+k)=*(p+i);
*(p+i)=s1;}
}
}
编译后提示
binary '>' : 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' does not define this operator or a conversion to a type acceptable to the predefined operator 展开
#include<string>
const int n=10;
using namespace std;
int main()
{string str[n];
void sort(string *,int n);
cout<<"please input ten strings:"<<endl;
for(int i=0;i<10;i++)
getline(cin,str[i]);
sort(str,n);
for(i=0;i<10;i++)
cout<<str[i]<<endl;
return 0;
}
void sort(string *p,int n)
{string s1;
int k;
for(int i=0;i<n-1;i++)
{k=i;
for(int j=i+1;j<n;j++)
{if(*(p+k)>*(p+j))
{k=j;
s1=*(p+k);
*(p+k)=*(p+i);
*(p+i)=s1;}
}
}
编译后提示
binary '>' : 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' does not define this operator or a conversion to a type acceptable to the predefined operator 展开
展开全部
#include<iostream>
#include<string>
const int n=10;
using namespace std;
int main()
{ string str[n];
void sort(string *,int n);
cout<<"please input ten strings:"<<endl;
for(int i=0;i<10;i++)
getline(cin,str[i]);
sort(str,n);
for(i=0;i<10;i++)
cout<<str[i]<<endl;
return 0;
}
void sort(string *p,int n)
{ string s1;
int k;
for(int i=0;i<n-1;i++)
{ k=i;
for(int j=i+1;j<n;j++)
{
if(*(p+k)>*(p+j))
{
k=j;
s1=*(p+k);
*(p+k)=*(p+i);
*(p+i)=s1;
}
}
}
}
/////最后少了一个}
#include<string>
const int n=10;
using namespace std;
int main()
{ string str[n];
void sort(string *,int n);
cout<<"please input ten strings:"<<endl;
for(int i=0;i<10;i++)
getline(cin,str[i]);
sort(str,n);
for(i=0;i<10;i++)
cout<<str[i]<<endl;
return 0;
}
void sort(string *p,int n)
{ string s1;
int k;
for(int i=0;i<n-1;i++)
{ k=i;
for(int j=i+1;j<n;j++)
{
if(*(p+k)>*(p+j))
{
k=j;
s1=*(p+k);
*(p+k)=*(p+i);
*(p+i)=s1;
}
}
}
}
/////最后少了一个}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询