工具软件   办公软件   操作系统   网络安全   设计在线   程序开发   教程宝典   软件下载   软件论坛
您的位置:软件 > 开发者网络 > 开发工具 > 开发专栏 > C/C++ > 正文
利用C++编写一个猜字游戏
[文章信息]
作者:邹浩浩
时间:2004-11-18
出处:天极网
责任编辑:方舟
[文章导读]
今天,我们要用C++来写一个猜字母的游戏。不要担心,做起来并不是那么难的
advertisement
热点推荐
· 真没想到VB也可以这样用之指针技术
· 禁止QQ登录的方法
· 给你的XML文件做个数字签名
· ImageReady制作“焰火”小动画
· Java加密和数字签名编程快速入门
[正文]

1 2  下一页

  今天,我们要用C++来写一个猜字母的游戏。不要担心,做起来并不是那么难的。首先,我们必须了解一下游戏规则。

  一:玩家每次只能猜一个字母;

  二:玩家只能猜错有限次,否则游戏失败;

  三:猜错的字母将被记录下来;

  四:每次猜测后,游戏应显示出当前猜出的残缺单词,以及当前猜错的所有字母,和剩下的猜错的机会;

  五:假设玩家猜的字母在单词中,单词中所有的该字母将被视为已猜出,例如:如果原单词是apple,我们猜出了p,则程序应显示当前猜出的残缺单词为-pp--。

  六:不得多次猜测同一个字母,因为这样是浪费时间。

  一:准备工作:

  
规则就是这么多,我们应该用C++代码来实现它。首先,我们应考虑怎样记录单词,其中包括原单词、猜错的字母、当前猜出的残缺单词。如果用传统的C风格数组,这是很麻烦的,这用C风格字符串实现很困难。但C++为我们预先想到了这一切,C++中带有一个功能强大的string类,它的声明在头文件string中。注意,cstring或string.h中只是包含了一些处理字符串的函数,不包括string类。要使用这个类,我们首先要知道它的构造函数,这样才能创建string类对象。
   

构造函数 说明
string(const char* s) 将string对象初始化为字符串s
string(size_type n,char c) 将对象初始化为有n个元素的对象,它们都是字符c
string(const string& str,size_type pos=0,size_type n=npos) 将对象初始化为str中,从第pos个元素开始的n个元素。

   其实,这个类的构造函数远不止这些,但我们开发这个游戏只用得到这些(也许还用不上这么多)。我们还要了解一些关于string类的知识。它重载了所有的关系操作符、可以用+=操作符把字符串、string类对象、字符加到对象的末尾。比如,我们可以写出这样的代码:string a="butter"; string b="fly"; a+=b;这是十分方便的。它还重载了[]操作符,使我们完全可以像常规数组一样用它。对于string类,我们还要初步了解一下它的输入选项。它有operator>>,所以我们可以用cin进行输入,并且它与istream中的cin的使用规则是一样的。值得注意的一点是,string类是一个比较智能的类,它能够自动调整字符串的长度,这样,我们就不用担心浪费空间或者输入字符串超出对象末尾了。而我们常用的getline()函数呢?这是一个成员函数,所以不能进行重载。解决的办法是,string类带有一个getline()的非成员函数,它接受两个参数,第一个是istream类对象,第二个是string类对象,并且去掉了长度参数,原因已经说了。所以,假设temp是一个string类对象,我们应这样对它使用getline():getline(cin,string);看起来有点不好看,但实用。

  最后,要实现这个拼字游戏,我们必须在对象中查找字符。string类已经提供了这方面的函数了,请看下表(未完全列出)。
 

方法原型 说明
size_type find(char ch,size_type pos=0)const; 从字符串的pos位置开始,查找字符ch,若找到,返回第一个ch所在的索引,
否则,返回string::npos。
size_type find(const string& str,size_type pos=0)const; 从字符串的pos位置开始,查找字符串str,若找到,返回str的首字母所在的索引,否则,返回string::npos。
size_type find (const char* s,size_type pos=0)const; 从字符串的pos位置开始,查找字符串s,若找到,返回s的首字母所在的索引,否则,返回string::npos。

    举例说明,若temp是一个string对象,内容为"apple",则temp.find('p')将返回1,即第一个字符p对应的索引。

  二:游戏源代码:

#include <iostream>
#include <string>
#include <cstdlib>
#include <ctime>
#include <cctype>
using namespace std;
const int NUM = 26;
const string wordlist[NUM] = {"alabama", "choice", "usually",
"dangerous", "deer", "panda", "love", "health", "exciting",
"interesting", "administrator", "professional", "manage", "nonce", "onset",
"typeid", "quarter", "remote", "lovely", "car", "keeper",
"valid", "where", "mean", "important", "last"};//供游戏的单词库

int main()
{
 srand(time(0));
 char play;
 cout << "Will you play a word game? <y/n> ";
 cin >> play;
 play = tolower(play);
 while(play=='y')
 {
  string first(wordlist[rand()%NUM]);//随机选择单词
  int length=first.length();
  string player(length,'-');//玩家猜测的单词
  string badguess;//猜错的字母集合
  int guesses=10;//猜错的机会
  char guess;
  cout<<"您有"<<guesses<<"次猜错的机会。\n";
  cout<<"您的单词:"<<player<<'\n';
  while(guesses>0&&player!=first)
  {
   cout<<"请您猜吧!";
   cin>>guess;
   if(badguess.find(guess)!=string::npos||player.find(guess)!=string::npos)
   {
    cout<<"对不起,这个字母您已经猜过了。";
    continue;
   }//判断是否已经猜过
   int temp=first.find(guess);
   if(temp==string::npos)
   {
    cout<<"啊!猜错了。\n";
    guesses--;
    badguess+=guess;
   }//猜错后的处理
   else
   {
    player[temp]=guess;
    temp=first.find(guess,temp+1);
    while(temp!=string::npos)//继续搜索该字符,看是否单词中有多个该字符
    {
     player[temp]=guess;
     temp=first.find(guess,temp+1);
    }
   }
   cout<<"您还剩下"<<guesses<<"次猜错的机会。\n";
   cout<<"您当前猜出的单词:"<<player<<'\n';
   cout<<"您当前猜错的字母集合:"<<badguess<<'\n';
  }
  if(guesses==0)
   cout<<"对不起,您失败了。\n";
  else
   cout<<"您真棒!\n";
   cout<<"正确单词为:"<<first<<'\n';
   cout << "Will you play again? <y/n> ";
   cin>>play;
 }

 system("PAUSE");
 return 0;
}

  下面是运行结果:

Will you play a word game? <y/n> y
您有10次猜错的机会。
您的单词:------------
请您猜吧!a
您还剩下10次猜错的机会。
您当前猜出的单词:----------a-
您当前猜错的字母集合:
请您猜吧!s
您还剩下10次猜错的机会。
您当前猜出的单词:-----ss---a-
您当前猜错的字母集合:
请您猜吧!p
您还剩下10次猜错的机会。
您当前猜出的单词:p----ss---a-
您当前猜错的字母集合:
请您猜吧!o
您还剩下10次猜错的机会。
您当前猜出的单词:p-o--ss-o-a-
您当前猜错的字母集合:
请您猜吧!r
您还剩下10次猜错的机会。
您当前猜出的单词:pro--ss-o-a-
您当前猜错的字母集合:
请您猜吧!f
您还剩下10次猜错的机会。
您当前猜出的单词:prof-ss-o-a-
您当前猜错的字母集合:
请您猜吧!e
您还剩下10次猜错的机会。
您当前猜出的单词:profess-o-a-
您当前猜错的字母集合:
请您猜吧!i
您还剩下10次猜错的机会。
您当前猜出的单词:professio-a-
您当前猜错的字母集合:
请您猜吧!n
您还剩下10次猜错的机会。
您当前猜出的单词:professiona-
您当前猜错的字母集合:
请您猜吧!l
您还剩下10次猜错的机会。
您当前猜出的单词:professional
您当前猜错的字母集合:
您真棒!
正确单词为:professional
Will you play again? <y/n> n
请按任意键继续. . .


1 2  下一页

发表评论推荐给朋友我想参加相关培训打印我对此感兴趣订阅电子杂志
相关内容焦点新闻
  • C++中的健壮指针和资源管理
  • C++中动态内存分配引发问题的解决方案
  • C++编程中的四个调试小技巧
  • C++程序设计之四书五经(上篇)
  • C++ 泛型编程系列讲座之实施
  • 民营家电商排队造手机 设备商全面杀入
  • 英特尔澄清杨旭任职传闻 官方没宣布此消息
  • 国资委河北密制联通拆分方案
  • 垃圾邮件害人害企害国 清除垃圾邮件不手软
  • 中兴携手阿尔卡特 全球逐鹿CDMA
  • 用友总裁王文京:誓将ERP变成“大众消费”
  • 香港消费者委员会:数码相机最贵未必最好
  • 外电称中兴正评估西门子手机业务 或能并购
  • Advertisement

    天极无线


    奇妙科幻|美好风光|清风车影|漫画卡通|星座生肖|明星写真|动物世界
    老鼠爱大米
    挥着翅膀的女孩
    女人味
    栀子花开
    白月光
    刚刚好
    江南
    快乐崇拜
    亲爱的你怎么不在我身边
    小薇
    2002年的第一场雪
    有多少爱可以重来
    我的地盘
    七里香
    情人
     
    老鼠爱大米 老板电话
    冲动的惩罚 七里香
    我不是黄蓉 女生撒娇
    盛夏的果实 坚持到底
    孤单北半球 眉飞色舞
    挪威的森林 可爱女人
    最浪漫的事 老板电话

    CSEEK搜索