Mini-project description — Rock-paper-scissors-lizard-Spock

Rock-paper-scissors is a hand game that is played by two people. The players count to three in unison and simultaneously "throw” one of three hand signals that correspond to rock, paper or scissors. The winner is determined by the rules:

  • Rock smashes scissors
  • Scissors cuts paper
  • Paper covers rock

Rock-paper-scissors is a surprisingly popular game that many people play seriously (see the Wikipedia article for details).
Due to the fact that a tie happens around 1/3 of the time, several variants of Rock-Paper-Scissors exist that include more choices to make ties less likely.

Rock-paper-scissors-lizard-Spock (RPSLS) is a variant of Rock-paper-scissors that allows five choices. Each choice wins against two other choices, loses against two other choices and ties against itself. Much of RPSLS's popularity is that it has been featured
in 3 episodes of the TV series "The Big Bang Theory". The Wikipedia entry for RPSLS gives the complete
description of the details of the game.

In our first mini-project, we will build a Python function rpsls(name) that
takes as input the string name, which is one of "rock""paper","scissors""lizard",
or "Spock". The function then simulates playing a round
of Rock-paper-scissors-lizard-Spock by generating its own random choice from these alternatives and then determining the winner using a simple rule that we will next describe.

While Rock-paper-scissor-lizard-Spock has a set of ten rules that logically determine who wins a round of RPSLS, coding up these rules would require a large number (5x5=25) of if/elif/else clauses
in your mini-project code. A simpler method for determining the winner is to assign each of the five choices a number:

  • 0 — rock
  • 1 — Spock
  • 2 — paper
  • 3 — lizard
  • 4 — scissors

In this expanded list, each choice wins against the preceding two choices and loses against the following two choices (if rock and scissors are thought of as being adjacent using modular arithmetic).

In all of the mini-projects for this class, we will provide a walk through of the steps involved in building your project to aid its development. A template for your mini-project is available
here
. Please work from this template.

Mini-project development process

  1. Build a helper function name_to_number(name) that
    converts the string name into a number between 0 and
    4 as described above. This function should use a sequence of if/elif/else clauses.
    You can use conditions of the form name == 'paper',
    etc. to distinguish the cases. To make debugging your code easier, we suggest including a final else clause
    that catches cases when name does not match any of the
    five correct input strings and prints an appropriate error message. You can test your implementation of name_to_number() using
    this name_to_number testing template. (Also available in the Code Clinic tips thread).
  2. Next, you should build a second helper function number_to_name(number) that
    converts a number in the range 0 to 4 into its corresponding name as a string. Again, we suggest including a final else clause
    that catches cases when number is not in the correct
    range. You can test your implementation of number_to_name() using
    this number_to_name testing template.
  3. Implement the first part of the main function rpsls(player_choice).
    Print out a blank line (to separate consecutive games) followed by a line with an appropriate message describing the player's choice. Then compute the number player_number between
    0 and 4 corresponding to the player's choice by calling the helper function name_to_number() using player_choice.
  4. Implement the second part of rpsls() that
    generates the computer's guess and prints out an appropriate message for that guess. In particular, compute a random number comp_number between
    0 and 4 that corresponds to the computer's guess using the function random.randrange().
    We suggest experimenting with randrange in a separate
    CodeSkulptor window before deciding on how to call it to make sure that you do not accidently generate numbers in the wrong range. Then compute the name comp_choice corresponding
    to the computer's number using the function number_to_name() and
    print an appropriate message with the computer's choice to the console.
  5. Implement the last part of rpsls() that
    determines and prints out the winner. Specifically, compute the difference between comp_number andplayer_number taken
    modulo five. Then write an if/elif/else statement whose
    conditions test the various possible values of this difference and then prints an appropriate message concerning the winner. If you have trouble deriving the conditions for the clauses of this if/elif/elsestatement,
    we suggest reviewing the "RPSLS" video which describes a simple test for determine the winner of RPSLS.

This will be the only mini-project in the class that is not an interactive game. Since we have not yet learned enough to allow you to play the game interactively, you will simply call your rpsls function
repeatedly in the program with different player choices. You will see that we have provided five such calls at the bottom of the template. Running your program repeatedly should generate different computer guesses and different winners each time. While you
are testing, feel free to modify those calls, but make sure they are restored when you hand in your mini-project, as your peer assessors will expect them to be there.

The output of running your program should have the following form:

Player chooses rock
Computer chooses scissors
Player wins! Player chooses Spock
Computer chooses lizard
Computer wins! Player chooses paper
Computer chooses lizard
Computer wins! Player chooses lizard
Computer chooses scissors
Computer wins! Player chooses scissors
Computer chooses Spock
Computer wins!

Note that, for this initial mini-project, we will focus only on testing whether your implementation of rpsls() works
correctly on valid input.

Grading rubric — 18 pts total (scaled to 100 pts)

Your peers will assess your mini-project according to the rubric given below. To guide you in determining whether your project satisfies each item in the rubric, please consult the video that demonstrates our implementation of "Rock-paper-scissors-lizard-Spock".
Small deviations from the textual output of our implementation are fine. You should avoid large deviations (such as using the Python function input to
input your guesses). Whether moderate deviations satisfy an item of the grading rubric is at your peers' discretion during their assessment.

Here is a break down of the scoring:

  • 2 pts — A valid CodeSkulptor URL was submitted. Give no credit if solution code was pasted into the submission field. Give 1 pt if an invalid CodeSkulptor URL was submitted.
  • 2 pts — Program implements the function rpsls() and
    the helper function name_to_number() with plausible
    code. Give partial credit of 1 pt if only the function rpsls() has
    plausible code.
  • 1 pt — Running program does not throw an error.
  • 1 pt — Program prints blank lines between games.
  • 2 pts — Program prints "Player chooses player_choice" where player_choice is
    a string of the form "rock""paper""scissors""lizard"or "Spock".
    Give 1 pt if program prints out number instead of string.
  • 2 pts — Program prints "Computer chooses comp_choice" where comp_choice is
    a string of the form "rock", "paper", "scissors", "lizard" or"Spock".
    Give 1 pt if program prints out number instead of string.
  • 1 pt — Computer's guesses vary between five calls to rpsls() in
    each run of the program.
  • 1 pt — Computer's guesses vary between runs of the program.
  • 3 pts — Program prints either "Player and computer
    tie!"
    "Player wins!" or "Computer
    wins!"
     to report outcome. (1 pt for each message.)
  • 3 pts — Program chooses correct winner according to RPSLS rules. Please manually examine 5 cases for correctness. If all five cases are correct, award 3 pts; four cases correct award 2 pts; one to three cases correct award 1 pt; no cases correct
    award 0 pts.

my_work:

<span style="font-size:18px;"># Rock-paper-scissors-lizard-Spock template

# The key idea of this program is to equate the strings
# "rock", "paper", "scissors", "lizard", "Spock" to numbers
# as follows:
#
# 0 - rock
# 1 - Spock
# 2 - paper
# 3 - lizard
# 4 - scissors
import random
# helper functions def name_to_number(name):
# delete the following pass statement and fill in your code below
if name == 'rock':
return 0
elif name == 'Spock':
return 1
elif name == 'paper':
return 2
elif name == 'lizard':
return 3
elif name == 'scissors':
return 4
else:
print 'wrong number' # convert name to number using if/elif/else
# don't forget to return the result! def number_to_name(number):
# delete the following pass statement and fill in your code below
if number == 0:
return 'rock'
elif number == 1:
return 'Spock'
elif number == 2:
return 'paper'
elif number ==3:
return 'lizard'
elif number ==4:
return 'scissors'
else:
print 'wrong number' # convert number to a name using if/elif/else
# don't forget to return the result! def rpsls(player_choice):
# delete the following pass statement and fill in your code below # print a blank line to separate consecutive games
print
# print out the message for the player's choice
print 'Player chooses ',player_choice
# convert the player's choice to player_number using the function name_to_number()
player_number = name_to_number(player_choice)
# compute random guess for comp_number using random.randrange()
comp_number = random.randrange(0,4)
# convert comp_number to comp_choice using the function number_to_name()
comp_choice = number_to_name(comp_number)
# print out the message for computer's choice
print 'Computer chooses', comp_choice
# compute difference of comp_number and player_number modulo five
minus_number = comp_number - player_number
result_of_modulo = minus_number % 5
# use if/elif/else to determine winner, print winner message
if result_of_modulo ==0:
print 'Player and computer tie!'
elif result_of_modulo > 2:
print 'Player wins!'
else:
print 'Computer wins!' # test your code - THESE CALLS MUST BE PRESENT IN YOUR SUBMITTED CODE
rpsls("rock")
rpsls("Spock")
rpsls("paper")
rpsls("lizard")
rpsls("scissors") # always remember to check your completed program against the grading rubric
</span>

代码链接:CodeSkulptor


Mini-project # 1 - Rock-paper-scissors-___An Introduction to Interactive Programming in Python"RICE"的更多相关文章

  1. Mini-project # 4 - "Pong"___An Introduction to Interactive Programming in Python"RICE"

    Mini-project #4 - "Pong" In this project, we will build a version of Pong, one of the firs ...

  2. An Introduction to Interactive Programming in Python (Part 1) -- Week 2_3 练习

    Mini-project description - Rock-paper-scissors-lizard-Spock Rock-paper-scissors is a hand game that ...

  3. 【python】An Introduction to Interactive Programming in Python(week two)

    This is a note for https://class.coursera.org/interactivepython-005 In week two, I have learned: 1.e ...

  4. An Introduction to Interactive Programming in Python (Part 1) -- Week 2_2 练习

    #Practice Exercises for Logic and Conditionals # Solve each of the practice exercises below. # 1.Wri ...

  5. An Introduction to Interactive Programming in Python (Part 1) -- Week 2_1 练习

    # Practice Exercises for Functions # Solve each of the practice exercises below. # 1.Write a Python ...

  6. An Introduction to Interactive Programming in Python

    这是在coursera上面的一门学习pyhton的基础课程,由RICE的四位老师主讲.生动有趣,一共是9周的课程,每一周都会有一个小游戏,经历一遍,对编程会产生很大的兴趣. 所有的程序全部在老师开发的 ...

  7. Quiz 6b Question 8————An Introduction to Interactive Programming in Python

     Question 8 We can use loops to simulate natural processes over time. Write a program that calcula ...

  8. Quiz 6b Question 7————An Introduction to Interactive Programming in Python

     Question 7 Convert the following English description into code. Initialize n to be 1000. Initiali ...

  9. Quiz 6a Question 7————An Introduction to Interactive Programming in Python

     First, complete the following class definition: class BankAccount: def __init__(self, initial_bal ...

随机推荐

  1. JAVA泛型-擦除

    package com.xt.thinks15_7; import java.util.Arrays; class EraseObject1<A> { } class EraseObjec ...

  2. JAVA的BIT数组

    写个小东西,要去重复数字,用到BIT数组,虽然JAVA已经提供了一个BitSet,不过自己手痒,又写了一个简单的 原理就不写了,网上一大堆 import java.util.Iterator; imp ...

  3. Qt全屏显示窗口、子窗口的相关函数

    Qt全屏显示函数         window.showFullScreen() Qt最大化显示函数         window.showMaximized() Qt最小化显示函数         ...

  4. HelloX项目github协同开发指南

    概述 为了提高协同开发效率,HelloX项目已托管到github网站上.根据目前的开发进展,创建了下列几个子项目: HelloX操作系统内核项目:https://github.com/hellox-p ...

  5. kafka集群搭建与apiclient创建

    曾经的消息队列(activeMQ)对于大数据吞吐率不行,但kafka非常好的攻克了此类问题.而且以集群的方式进行扩展.可谓相当强大: 集群搭建方式很轻量级.仅仅需将tar包复制到server,解压,改 ...

  6. Android 之窗口小部件高级篇--App Widget 之 RemoteViews - 跨到对岸去

    在之前的一篇博文( Android 之窗口小部件详解--App Widge t)中,已经介绍了App Widget的基本用法和简单实例.这篇主要讲解 App Widget 的高级内容,即通过 Remo ...

  7. vs2010 项目编译 ResGen.exe”已退出,代码为 -1073741701

    解决的办法如下: 1.关闭所有Visual Studio: 2.以管理员的身份打开命令提示窗口:(开始-运行-cmd) 3.更改目录至"CD C:\Program Files (x86)\M ...

  8. 笔记-Nodejs中的核心API之Events

    最近正在学习Node,在图书馆借了基本关于Node的书,同时在网上查阅资料,颇有收获,但是整体感觉对Node的理解还是停留在一个很模棱两可的状态.比如Node中的模块,平时练习就接触到那么几个,其他的 ...

  9. CSS通用编码规范

    CSS通用编码规范 总结一部分前端编码规范,CSS部分先奉上,大多比较通用,应该是主流方式吧. 1 前言 本文档的目标是使 CSS 代码在团队中风格保持一致,容易被理解和被维护. 尽管本文档是针对 C ...

  10. 驴吃胡萝卜问题——牛客/FEI

    一个商人骑一头驴要穿越1000公里长的沙漠,去卖3000根胡萝卜.已知驴一次性可驮1000根胡萝卜,但每走1公里又要吃掉1根胡萝卜.问:商人最多可卖出多少胡萝卜? 一个商人骑一头驴要穿越1000公里长 ...