FizzBuzzWhizz 游戏


import java.util.Scanner;

public class FizzBuzzWhizz {

/**
* 你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏。此时有100名学生在上课。游戏的规则是:
*
* 1 )你首先说出三个不同的特殊数,要求必须是个位数,比如3、5、7。
   * 2 )让所有学生拍成一队,然后按顺序报数。
*
* 3 )学生报数时,如果所报数字是第一个特殊数
* (3)的倍数,那么不能说该数字,而要说Fizz;如果所报数字是第二个特殊数
* (5)的倍数,那么要说Buzz;如果所报数字是第三个特殊数
* (7)的倍数,那么要说Whizz。
   *
* 4 )学生报数时,如果所报数字同时是两个特殊数的倍数情况下,也要特殊处理,比如第一个特殊数和第二个特殊数的倍数,那么不能说该数字
* ,而是要说FizzBuzz, 以此类推。如果同时是三个特殊数的倍数,那么要说FizzBuzzWhizz。
*
* 5 )学生报数时,如果所报数字包含了第一个特殊数
* ,那么也不能说该数字,而是要说相应的单词,比如本例中第一个特殊数是3,那么要报13的同学应该说Fizz。如果数字中包含了第一个特殊数
* ,那么忽略规则3和规则4,比如要报35的同学只报Fizz,不报BuzzWhizz。
* 现在,我们需要你完成一个程序来模拟这个游戏,它首先接受3个特殊数,然后输出100名学生应该报数的数或单词。比如, 输入3,5,7
   *
* 6 )输出(片段)
*
* @param args
*/

public static void main(String[] args) {
int a = 0;
int b = 0;
int c = 0;
try {
//System.in.read() 得到的是一个字符char ascii码,数字开始的ascii码 0 为 48
// -1会报错
// a = Integer.parseInt((char)System.in.read()+"");
// b = Integer.parseInt((char)System.in.read()+"");
// c = Integer.parseInt((char)System.in.read()+"");

//另一种接收控制台输入
System.out.println("请输入三个一位个数字");
Scanner in = new Scanner(System.in);
a = in.nextInt();
b = in.nextInt();
c = in.nextInt();

} catch (Exception e) {
try {
throw new Throwable("您输入的不是数字");
} catch (Throwable e1) {
e1.printStackTrace();
}
}
System.out.println("--------------------");

int i = 1;
while(i <= 100){
String con = "";

//第一个数 a 的倍数 打印 Fizz
con = (i%a == 0)?con+"Fizz":con;
//第二个数 b 的倍数 打印 Buzz
con = (i%b == 0)?con+"Buzz":con;
//第三个数 c 的倍数 打印 Whizz
con = (i%c == 0)?con+"Whizz":con;

con = (con.length() == 0)?i+"":con;

//如果所报数字包含了第一个特殊数 打印 Fizz
// 1- 100
con = (i%10 == a || i%100/10 == a || i%1000/100 == a)?"Fizz":con;
System.out.println(con);
i++;
}
}

}

FizzBuzzWhizz 游戏

时间: 2024-10-29 20:43:38

FizzBuzzWhizz 游戏的相关文章

最难面试的IT公司之ThoughtWorks代码挑战——FizzBuzzWhizz游戏(C#解法)

原题 一开始楼主傻BB直接求解,思路惨不忍睹,各种循环啊有木有?还写了个计算是否整除扩展方法以为重复复用很了不起啊(其实是傻...) 二逼青年的代码 1   #region so1 2             int[] count = new int[100]; 3             string[] s4 = new string[] { "Fizz", "Buzz", "Whizz" }; 4             for (int

FizzBuzzWhizz游戏的js解法

5.6休假回来在园子里看到一道比较火的面试题:(链接地址),js解法代码: function test(a, b, c) { var s = [false, "Fizz", "Buzz", "FizzBuzz", "Whizz", "FizzWhizz", "BuzzWhizz", "FizzBuzzWhizz"], mod = function(n, a, rv)

ThoughtWorks代码挑战——FizzBuzzWhizz游戏 通用高速版(C/C++ &amp; C#)

最早看到这个题目是从@ 程序媛想事儿(Alexia) 的 最难面试的IT公司之ThoughtWorks代码挑战--FizzBuzzWhizz游戏 开始的,然后这几天陆陆续续有N个小伙伴发表了自己的文章和代码,本来不想做些什么,但是看了这么多代码,总有点想写(射)点什么的欲望(你玩英雄联盟吗?玩的话,应该知道我说的是什么). 我说说我对这个题目的看法,当初看Alexia的文章时,也没有看得很仔细,甚至没有看这个题目的原出处,一边在玩英雄联盟,一边看了一下题目,Alexia并没有贴出相应的代码要求(

编译器是如何实现32位整型的常量整数除法优化的?[C/C++]

引子 在我之前的一篇文章[ ThoughtWorks代码挑战——FizzBuzzWhizz游戏 通用高速版(C/C++ & C#) ]里曾经提到过编译器在处理被除数为常数的除法时,是有优化的,今天整理出来,一来可以了解是怎么实现的,二来如果你哪天要写编译器,这个理论可以用得上.此外,也算我的一个笔记. 实例 我们先来看一看编译器优化的实例.我们所说的被除数为常数的整数除法(针对无符号整型, 有符号整型我们后面再讨论),指的是,对于unsigned int a, b, c,例如:a / 10, b

我的2014碎碎念—学习篇、实习篇、工作篇、生活篇

继去年作了一次年度总结过后,我就发誓说以后每年年末都要做一次总结,这对自己是非常有帮助的,无奈由于天性懒散,2015年都过去好几天了,才花了点心思整理下自己在过去一年里的所得所失,给过去的自己盖个章,给未来的自己提个醒! 学习篇 为了传播正能量,一开始就先总结下自己这一年的学习生涯吧. 发表研究生小论文可以说14年大半年的时间都花在了做研究生论文项目上面,幸好最终出了一篇小论文并得以发表录用,了了研究生期间最重要的一件事(看来毕业不成问题了). 读书学习总离不开看书,14年的读书情况可以分为两个

FizzBuzzWhizz

FizzBuzzWhizz你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏.此时有100名学生在上课.游戏的规则是: 1. 你首先说出三个不同的特殊数,要求必须是个位数,比如3.5.7. 2. 让所有学生拍成一队,然后按顺序报数. 3. 学生报数时,如果所报数字是第一个特殊数(3)的倍数,那么不能说该数字,而要说Fizz:如果所报数字是第二个特殊数(5)的倍数,那么要说Buzz:如果所报数字是第三个特殊数(7)的倍数,那么要说Whizz. 4. 学生报数时,如果所报数字同时是两个

FizzBuzzWhizz问题python解法

FizzBuzzWhizz 你是一名体育老师,在某次课距离下课还有五分钟时,你决定搞一个游戏.此时有100名学生在上课.游戏的规则是: 1. 你首先说出三个不同的特殊数,要求必须是个位数,比方3.5.7. 2. 让全部学生拍成一队,然后按顺序报数. 3. 学生报数时,假设所报数字是第一个特殊数(3)的倍数,那么不能说该数字,而要说Fizz:假设所报数字是第二个特殊数(5)的倍数,那么要说Buzz:假设所报数字是第三个特殊数(7)的倍数,那么要说Whizz. 4. 学生报数时,假设所报数字同一时候

打个酱油,欢迎指正FizzBuzzWhizz(c#)

平民的代码,列表法,凑个热闹,做了简单的测试,太晚了就不写测试用例了 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Threading.Tasks; 6 7 namespace FizzBuzzWhizz 8 { 9 class Program 10 { 11 static bool checkisvalid(string v

20170913自制猜数字游戏

/* 猜数字:系统随机生成一个四位数,请根据下列判断猜出来 A:数值正确,位置正确 B:数值正确,位置不正确 C:数值不正确 */ #include<stdio.h> #include<time.h> #include<stdlib.h> #pragma warning (disable:4996) #define pUCharHead unsigned char * //以数组形式返回n个无重复的随机数,范围可指定[min,max] pUCharHead GenNoR