- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
作为学习练习,我想对不同文件中不同类型的数字进行排序。我已经设法让 double 和整数正确排序,但无法让我自己的类型(对一副牌排序)正确格式化。我设法将它缩小到我的Reader 类中的排序函数。我遇到了各种各样的错误。我到底做错了什么?或者我错过了什么?谢谢大家,我希望我能把我的问题解释清楚。
我为卡片创建的文件看起来像...
1 11 (meaning Jack of Diamonds)
2 8 (meaning 8 of hearts)
等...
错误:
error: no match for 'operator<' in '((Reader)this)->Reader::array[compareIndex] < ((Reader)this)->Reader::array[smallestIndex]'
error: cannot convert 'Card' to 'int' in initialization
error: no match for 'operator=' in '((Reader*)this)->Reader::array[smallestIndex] = temp'
我的代码
最后,主要
#include <iostream>
#include "Reader.h"
#include "Card.h"
using namespace std;
int main() {
Reader<int> nums;
Reader<double> dubs;
Reader<Card> cards;
int number;
do {
cout << "Enter 1 if your file contains integers\n"
<< "Enter 2 if your file contains doubles\n"
<< "Enter 3 if your file contains Cards:\n"
<< "Enter a number: ";
cin >> number;
if (number == 1){
nums.open_IO();
nums.read_array();
nums.sort();
nums.write_array();
nums.close_IO();
} else if (number == 2){
dubs.open_IO();
dubs.read_array();
dubs.sort();
dubs.write_array();
dubs.close_IO();
} else if (number == 3){
cards.open_IO();
cards.read_array();
cards.sort();
cards.write_array();
cards.close_IO();
}
} while ((number != 1) && (number != 2) && (number != 3));
}
Reader.h
#ifndef READER_H
#define READER_H
#include <string>
#include <fstream>
using namespace std;
template <class rList>
class Reader {
public:
static const int SIZE = 50;
Reader();
bool open_IO();
void close_IO();
bool read_array();
bool write_array();
void sort();
private:
// Ask for the files
void ask_filenames();
rList array[SIZE];
int readSize;
// input file names and stream to get the data
string readFileName;
ifstream inFile;
// output file names and stream to get the data
string writeFileName;
ofstream outFile;
bool askedFileNames;
};
#endif
#include "Reader.cpp"
我的Reader.Cpp文件
// File: Reader.cpp
#ifndef READER_CPP
#define READER_CPP
#include "Reader.h"
#include <iostream>
using namespace std;
/***************************************************************************
* Contructors and modifying functions defined in "Reader.h"
***************************************************************************/
template <class rList>
Reader<rList>::Reader() {
askedFileNames = false;
readFileName = "";
writeFileName = "";
readSize = 0;
rList empty;
for( int i = 0; i<SIZE; i++ ) array[i]=empty;
}
template <class rList>
bool Reader<rList>::open_IO(){
if(!askedFileNames) ask_filenames();
inFile.open(readFileName.c_str()); //we can't pass a string, we need a char array
if(!inFile.is_open()) {
return false;
}
outFile.open(writeFileName.c_str());
if(!outFile.is_open()) {
inFile.close(); //inFile opened successfully so it needs to be closed now
return false;
}
return true;
}
template <class rList>
void Reader<rList>::close_IO() {
inFile.close();
outFile.close();
}
template <class rList>
bool Reader<rList>::read_array() {
if(inFile.is_open()) {
inFile >> readSize;
int index = 0;
while(!inFile.eof() && index < readSize) {
inFile >> array[index++]; //increments index after assigning value
}
readSize = index; //the input file could have had fewer numbers so set readSize
return true;
}
return false;
}
template <class rList>
bool Reader<rList>::write_array() {
if(outFile.is_open()) {
outFile << readSize << endl;
//don't forget the number indicating the element co
int index = 0;
while(index < readSize) {
outFile << array[index++] << endl;
}
return true;
}
return false;
}
template <class rList>
void Reader<rList>::sort() {
int startIndex = 0;
int compareIndex;
int smallestIndex;
bool smallerFound;
while(startIndex < readSize) {
smallestIndex = startIndex;
compareIndex = startIndex + 1;
smallerFound = false;
while(compareIndex < readSize) { //find the smallest value from the starting index
if(array[compareIndex] < array[smallestIndex]) {
smallestIndex = compareIndex;
smallerFound = true;
}
compareIndex++;
}
if(smallerFound) { //only swap the values if a smaller value is found
int temp = array[startIndex];
array[startIndex] = array[smallestIndex];
array[smallestIndex] = temp;
}
startIndex++;
}
}
/*--------------------------------------------------------------
This function asks the user for the filenames. This operation
is placed in a separate function because it is called multiple
times.
--------------------------------------------------------------*/
template <class rList>
void Reader<rList>::ask_filenames() {
cout << "Welcome. Please type in the name of the file to read the numbers.\n";
cin >> readFileName;
cout << "Thank you. Please type in the name of the file to write the numbers.\n";
cin >> writeFileName;
askedFileNames = true;
}
#endif
卡片.h
#include <ostream>
#include <string>
#include "Reader.h"
using namespace std;
class Card{
public:
static const int SIZE = 50;
enum SUIT {clubs, diams, hears, spads };
enum RANK {ace=1, two, thr, fou, fiv, six, sev, eig, nin, ten, jac, que, kin};
Card();
Card(int newSuit, int newRank);
void change(int newSuit, int newRank);
friend ostream& operator << ( ostream& out, Card theCard );
friend istream& operator >> ( istream& in, Card theCard );
private:
void change_rank(int newRank);
void change_suit(int newSuit);
string get_rank() const;
string get_suit() const;
SUIT suit;
RANK rank;
};
卡片.cpp
#include <iostream>
#include <string>
#include "Card.h"
using namespace std;
Card::Card() { suit = spads; rank = ace; }
Card::Card(int newSuit, int newRank) {
change(newSuit, newRank);
}
void Card::change( int newSuit, int newRank ) {
change_suit( newSuit );
change_rank( newRank );
}
ostream& operator << ( ostream& out, Card theCard ) {
out << theCard.get_rank() << " of " << theCard.get_suit();
return out;
}
istream& operator >> ( istream& in, Card theCard ) {
int aSuit;
int aRank;
in >> aSuit >> aRank;
return in;
}
// private member functions to set the private variables with their
// corresponding values: integer input -> enumerated type;
void Card::change_rank( int newRank ) {
if( newRank == ace ) rank = ace;
else if( newRank == two ) rank = two;
else if( newRank == thr ) rank = thr;
else if( newRank == fou ) rank = fou;
else if( newRank == fiv ) rank = fiv;
else if( newRank == six ) rank = six;
else if( newRank == sev ) rank = sev;
else if( newRank == eig ) rank = eig;
else if( newRank == nin ) rank = nin;
else if( newRank == ten ) rank = ten;
else if( newRank == jac ) rank = jac;
else if( newRank == que ) rank = que;
else if( newRank == kin ) rank = kin;
}
void Card::change_suit( int newSuit ) {
if( newSuit == clubs ) suit = clubs;
else if( newSuit == spads ) suit = spads;
else if( newSuit == diams ) suit = diams;
else if( newSuit == hears ) suit = hears;
}
// Private member functions to extract the information from the card
// class.
string Card::get_rank() const {
if( rank == ace ) return "ace";
if( rank == two ) return "two";
if( rank == thr ) return "three";
if( rank == fou ) return "four";
if( rank == fiv ) return "five";
if( rank == six ) return "six";
if( rank == sev ) return "seven";
if( rank == eig ) return "eight";
if( rank == nin ) return "nine";
if( rank == ten ) return "ten";
if( rank == jac ) return "jack";
if( rank == que ) return "queen";
if( rank == kin ) return "king";
return "get_rank: error";
}
string Card::get_suit() const {
if( suit == diams ) return "D";
if( suit == hears ) return "H";
if( suit == spads ) return "S";
if( suit == clubs ) return "C";
return "get_suit: error";
}
最佳答案
如果您使用 std::vector<Card>
而不是 C 数组,你重载了 operator<
对于 Card
, 你可以获得标准库来为你洗牌和排序。
vector<T>
是标准库自带的容器。这是一个可以存储类型元素的类模板 T
. T
可以是数字类型,std::string
甚至是 struct
或 class
.
这是为 Card
重载小于运算符的方法:
bool Card::operator<(const Card& other)
{
return true if this card is smaller than the other card;
// You may want to order by rank, then by suit, or vice-versa.
}
定义了这个运算符后,标准库容器和算法现在将“知道”如何订购您的 Cards
.
以下是使用 vector
的方法的 Card
std::vector<Card> deck(52); // Initially sized to 52 elements
// Populate deck just like you would an array
deck[0] = Card(diams, ace);
etc...
// Sort the deck
std::sort(deck.begin(), deck.end());
// Shuffle the deck
std::random_shuffle(deck.begin(), deck.end());
// Get the 5th card in the deck
Card fifth = deck[4];
std::sort
使用快速排序算法,它比您编写的冒泡排序快得多(无意冒犯:-)。很难编写可以击败标准库提供的手工数据结构和算法。编译器作者花了数年时间来完善和调整他们的标准库实现。
当您使用标准库容器时,您就拥有了一个标准库算法库供您使用。这使您可以专注于解决问题,而不是一遍又一遍地重写相同的基本算法和数据结构。
关于C++ 模板和类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12240273/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!