C++ 读写游戏文件
我正在用随机初始化的字母ex.B a S T E N制作一个游戏,用户将只使用这些字母键入尽可能多的单词。我有一个文件,里面有正确的单词和对应的点。我的问题是如何防止用户反复使用相同的单词 我正在尝试使用ofstream,这样每当用户输入正确的单词时,它就会被添加到空白文件中C++ 读写游戏文件,c++,fstream,ifstream,ofstream,turbo-c++,C++,Fstream,Ifstream,Ofstream,Turbo C++,我正在用随机初始化的字母ex.B a S T E N制作一个游戏,用户将只使用这些字母键入尽可能多的单词。我有一个文件,里面有正确的单词和对应的点。我的问题是如何防止用户反复使用相同的单词 我正在尝试使用ofstream,这样每当用户输入正确的单词时,它就会被添加到空白文件中 void start() { char ch; do { clrscr(); long* newptr = 0; time_t start = time(ne
void start()
{
char ch;
do {
clrscr();
long* newptr = 0;
time_t start = time(newptr);
char arr[10][50] = {" B A N S E T ", " R E D G A E ", " S A H L E S ", " P R G N I S ",
" A L E R L Y ", " L A C S A U ", " A C Q U K Y ", " M B L U E J ",
" Z E D Z U B ", " L E A Z D Z "};
int i = 0, sum, x;
while (i != 2) {
clrscr();
sum = 0;
do {
clrscr();
cout << "\t**********************************************\n";
cout << "\t* W O R D S E E K E R *\n";
cout << "\t**********************************************\n";
cout << "\n\t\t\t\t\t SCORE: " << sum << " /50 pts"
<< "\n ******************************\n";
cout << " * " << arr[i] << " *\n";
cout << " ******************************\n\n";
cout << " 6 letter=10pts, 5 letter=8pts, 4 letters=6pts, 3 letter=4pts\n\n";
char a[20], b[20];
int c;
// this is where I have my problem
if (i == 0) {
ifstream fin;
fin.open("lvl1.txt");
if (fin.fail()) {
cout << "File doesn't exist!";
exit(1);
}
ofstream fout;
fout.open("trial.txt");
if (fout.fail()) {
cout << "Output file opening failed.\n";
}
cout << "\tEnter word: ";
cin >> a;
do {
fout << a;
fin >> b >> c;
if (fin.eof() == 1) {
cout << "Incorrect! Try Again!";
delay(1000);
exit(1);
}
} while (strcmp(a, b) != 0);
fin.close();
if (strcmp(a, b) == 0) {
sum += c;
}
}
} while (sum < 50);
i++;
}
x = time(newptr) - start;
cout << "\n\tGood Job! Your time is " << x << " seconds\n";
cout << "\tDo you want to continue?(Y/N): ";
cin >> ch;
} while (ch != 'n' || ch != 'N');
}
问题是您是想在运行时还是在程序结束后记住这些单词 要在程序结束后记住单词,请将它们写入文件
要记住用户在运行时输入的单词,请使用容器,如std::vector。将单词附加到容器中,然后对容器进行排序。在附加之前,您可以使用std::binary\u搜索在容器中查找单词。请以可读的格式显示代码。我不会读你的乱码。每行一条语句,适当的缩进,等等。甚至还有一些程序可以为您进行格式化。使用它们。@RolandIllig我已经编辑了ifstream和ofstream所在的部分,如果这是一个混乱的地方,很抱歉。我为您使用了clang格式。如果您自己没有使用叮当格式,那么您将来可以使用一个用于此目的的。@NikosC。非常感谢,很抱歉,对于这类东西我还是个傻瓜。最好是后者,这样我就不需要每次新用户尝试播放时都从文件中删除这些单词。我忘了告诉你,我只允许使用Turbo C++。它是一个PrimeCuffice,你的指导老师为什么你必须使用Turbo C++,一个非常古老的编译器,当你可以免费下载一个现代免费编译器或者使用一个在线编译器来处理小项目。学校真的需要改变它的课程。一个很好的解决问题的方法是std::unordered_set而不是std::vector。如果你没有std::vector,你需要自己写。动态分配一个大小为N的数组。当数组已满时,分配一个新的、更大的数组;将旧数组复制到新数组,然后删除旧数组。另一个建议是编写自己的链表,并对单词使用插入排序。