搬山游戏

设有n座山,计算机与人为比赛的双方,轮流搬山。规定每次搬山的数止不能超 过k座,谁搬最后一座谁输。游戏开始时。计算机请人输入山的总数(n)和每次允许搬山的最大数止(k)。然后请人开始,等人输入了需要搬走的山的数目后,计算机马上打印出它搬多少座山,并提示尚余多少座山。双方轮流搬山直到最后一座山搬完为止。计算机会显示谁是赢家,并问人是否要继续比赛。若人不想玩了,计算机便会统计出共玩了几局,双方胜负如何。

  *问题分析与算法设计

  计算机参加游戏时应遵循下列原则:

  1) 当:

  剩余山数目-1<=可移动的最大数k 时计算机要移(剩余山数目-1)座,以便将最后一座山留给人。

  2)对于任意正整数x,y,一定有:

  0<=x%(y+1)<=y

  在有n座山的情况下,计算机为了将最后一座山留给人,而且又要控制每次搬山的数目不超过最大数k,它应搬山的数目要满足下列关系:

  (n-1)%(k+1)

  如果算出结果为0,即整除无余数,则规定只搬1座山,以防止冒进后发生问题。

  按照这样的规律,可编写出游戏程序如下:

  #include

  int main()

  {

  int n,k,x,y,cc,pc,g;

  printf("More Mountain Game\n");

  printf("Game Begin\n");

  pc=cc=0;

  g=1;

  for(;;)

  {

  printf("No.%2d game \n",g++);

  printf("---------------------------------------\n");

  printf("How many mpuntains are there?");

  scanf("%d",&n);

  if(!n) break;

  printf("How many mountains are allowed to each time?");

  do{

  scanf("%d",&k);

  if(k>n||k<1) printf("Repeat again!\n");

  }while(k>n||k<1);

  do{

  printf("How many mountains do you wish movw away?");

  scanf("%d",&x);

  if(x<1||x>k||x>n) /*判断搬山数是否符合要求*/

  {

  printf("IIIegal,again please!\n");

  continue;

  }

  n-=x;

  printf("There are %d mountains left now.\n",n);

  if(!n)

  {

  printf("...............I win. You are failure...............\n\n");cc++;

  }

  else

  {

  y=(n-1)%(k+1); /*求出最佳搬山数*/

  if(!y) y=1;

  n-=y;

  printf("Copmputer move %d mountains away.\n",y);

  if(n) printf(" There are %d mountains left now.\n",n);

  else

  {

  printf("...............I am failure. You win..................\n\n");

  pc++;

  }

  }

  }while(n);

  }

  printf("Games in total have been played %d.\n",cc+pc);

  printf("You score is win %d,lose %d.\n",pc,cc);

  printf("My score is win %d,lose %d.\n",cc,pc);

  }

转载于:https://www.cnblogs.com/fengxuewo/archive/2012/10/16/2726060.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来回答你的问题。首先,感谢你对ChitGPT的支持。现在,请问你的问题是什么呢? 至于你的题目,这是一个经典的博弈问题,也被称为“拈堆”游戏。我们可以使用循环方法来实现这个游戏。以下是一个可能的实现方案: ```python while True: n = int(input("请输入山的总数n:")) k = int(input("请输入每次允许搬山的最大数k:")) # 游戏开始,玩家先手 turn = "player" while n > 0: if turn == "player": # 玩家输入需要搬走的山的数目 move = int(input("请玩家输入需要搬走的山的数目(不能超过{}):".format(k))) while move > k or move < 1 or move > n: move = int(input("请重新输入需要搬走的山的数目(不能超过{}):".format(k))) n -= move print("玩家搬走了{}座山,还剩{}座山。".format(move, n)) turn = "computer" else: # 计算机随机搬山 move = min(n, k) n -= move print("计算机搬走了{}座山,还剩{}座山。".format(move, n)) turn = "player" # 游戏结束,判断胜负 if turn == "player": print("玩家赢了!") else: print("计算机赢了!") # 询问是否要继续比赛 again = input("是否要继续比赛?(输入y继续,其他键退出)") if again != "y": break print("共玩了{}局,玩家胜{}局,计算机胜{}局。".format(game_count, player_win, game_count - player_win)) ``` 在这个实现中,我们首先进入一个无限循环,让玩家可以在游戏结束后选择是否继续比赛。在每次循环开始时,我们会询问玩家输入山的总数n和每次允许搬山的最大数k。然后,我们进入一个双方轮流搬山的循环,直到最后一座山搬完为止。在每一轮中,我们会根据当前是谁的回合,让玩家或计算机进行搬山操作。在玩家回合中,我们会询问玩家需要搬走多少座山,直到输入合法为止。在计算机回合中,我们会随机搬走1到k座山每次搬山后,我们会打印出搬走的座山数以及剩余的山数。游戏结束后,我们会根据最后一次搬山的人判断胜负,并打印出胜利者。最后,我们会询问玩家是否要继续比赛,如果不想继续,就跳出循环并统计胜负情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值