【C++错误检查】binary '>>' :
2016-06-03 11:47
351 查看
f:\00数据结构编程\八排序\11.cpp(26) : error C2679:
binary '>>' : no operator defined which takes a right-hand operand of type 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' (or there is no acceptable conver
sion)
f:\00数据结构编程\八排序\11.cpp(37) : error C2679: binary '<<' : no operator defined which takes a right-hand operand of type 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' (or there is no
acceptable conver
sion)
错误原因:
(1):没加#include <string>
(2):程序中<<加了返回值为void类型的函数
<strong><span style="font-size:14px;">#include <iostream>
<span style="color:#ff0000;">//#include<string></span> //加了以后编译成功
#include <algorithm>
using namespace std;
typedef struct
{
string dna;
int count;
}DNA;
DNA dna[101];
int cmp(const void *a,const void *b)
{
DNA *aa = (DNA *)a;
DNA *bb = (DNA *)b;
return aa->count-bb->count;
}
int main()
{
int n,m;
char c;
cin>>n>>m;
int i;
for(i = 0; i < m; i++)
{
cin>>dna[i].dna;
dna[i].count = 0;
for(int j = 0; j < n; j++)
for(int k = j+1; k < n; k++)
{
if(dna[i].dna[j]>dna[i].dna[k])
dna[i].count++;
}
}
qsort(dna,m,sizeof(dna[0]),cmp);
for(i = 0; i < m; i++)
cout<<dna[i].dna<<endl;
return 0;
}</span></strong>
f:\00数据结构编程\八排序\11.cpp(26) : error C2679:
binary '>>' : no operator defined which takes a right-hand operand of type 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' (or there is no acceptable conver
sion)
f:\00数据结构编程\八排序\11.cpp(37) : error C2679: binary '<<' : no operator defined which takes a right-hand operand of type 'class std::basic_string<char,struct std::char_traits<char>,class std::allocator<char> >' (or there is no
acceptable conver
sion)
错误原因:
(1):没加#include <string>
(2):程序中<<加了返回值为void类型的函数
<strong><span style="font-size:14px;">#include <iostream>
<span style="color:#ff0000;">//#include<string></span> //加了以后编译成功
#include <algorithm>
using namespace std;
typedef struct
{
string dna;
int count;
}DNA;
DNA dna[101];
int cmp(const void *a,const void *b)
{
DNA *aa = (DNA *)a;
DNA *bb = (DNA *)b;
return aa->count-bb->count;
}
int main()
{
int n,m;
char c;
cin>>n>>m;
int i;
for(i = 0; i < m; i++)
{
cin>>dna[i].dna;
dna[i].count = 0;
for(int j = 0; j < n; j++)
for(int k = j+1; k < n; k++)
{
if(dna[i].dna[j]>dna[i].dna[k])
dna[i].count++;
}
}
qsort(dna,m,sizeof(dna[0]),cmp);
for(i = 0; i < m; i++)
cout<<dna[i].dna<<endl;
return 0;
}</span></strong>
相关文章推荐
- c++ 修改内存
- c++ int to byte
- windows下C语言多线程编程
- vs添加lib等依赖项
- C++的强制类型转换
- 用C语言实现Ping命令
- 快速离散傅里叶变换(FFT)C++实现
- 最短摘要生成
- C++ Primer 第十四章 重载操作符与转换
- c++中的new是什么东西?
- 平衡二叉树思想及C语言实现
- c++心得之struct和class(结构体和类)
- 学习c++对类的6个成员函数的简单总结
- C++函数前和函数后加const修饰符区别
- C++结构体、联合、枚举与C语言中的区别
- C++ string源码
- 通过模板的特化实现 简单的类型萃取 实现memcppy时候对于特殊类型如string类的拷贝。
- c++ 之广义表
- C语言时间函数使用详解
- C++范型程序补充阅读