C# 骑士飞行棋的源码(分享)
发布时间:2021-10-11 02:54:56
代码如下所示:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace 骑士飞行棋
{
class Program
{
//在下面的数组存储我们游戏地图各各关卡
//数组的下标为0的元素对应地图上的第1格 下标为1的元素对应元素第2格...下标为n的元素对应n+1格
//在数组中 1:表示幸运轮盘 ◎
// 2: 表示地雷 ☆
// 3: 表示暂停 ▲
// 4: 表示时空隧道 卍
// 0: 表示普通 □
static int[] map = new int[100];
static string[] names = new string[2]; //names[0]存储玩家A的姓名 name[1]存玩家B的姓名
static int[] playerPos = { 0, 0 };//playPos[0]存玩家A的位置,playPos[1]存玩家B的位置
static int step = 0; //用于存放产生的随机数
static string input = ""; //用户存储用户的输入
static string msg = ""; //用于存储用户踩到某个关卡,输出的话
static bool[] isStop = { false, false };//isStop[0]表示玩家A是否上次一走到暂停,似的话为true,不是为false
static Random r = new Random();//r是产生的随机数
static void Main( string[] args)
{
ShowUI(); //显示游戏
InitialName();
Console.Clear();
ShowUI();
Console.WriteLine("对战开始......");
Console.WriteLine("{0}用A来表示", names[0]);
Console.WriteLine("{0}用B来表示", names[1]);
Console.WriteLine("如果AB在同一位置,用<>表示");
InitialMap();//初始化地图
drawMap();//绘制地图
Console.WriteLine("开始游戏......");
//这个循环中让玩家A和玩家B轮流掷骰子 当玩家A或者玩家B的坐标>=99时,则循环结束
while (playerPos[0] < 99 && playerPos[1] < 99)
{
Action(0);//A掷筛子
Action(1);//B掷筛子
}
Console.ReadKey();
}
/// <summary>
/// 用于绘制飞行棋的名称
/// </summary>
static void ShowUI()
{
Console.WriteLine("*******************************************************");
Console.WriteLine("* *");
Console.WriteLine("* 骑 士 飞 行 棋 *");
Console.WriteLine("* *");
Console.WriteLine("*******************************************************");
}
static void InitialName()
{
Console.WriteLine("请输入玩家A的姓名");
names[0] = Console.ReadLine();
//判断用书输入的内容是否为空,如果为空,则让用户重新输入
while (names[0] == "")
{
Console.WriteLine("玩家A的姓名不能为空,请重新输入!");
names[0] = Console.ReadLine();
}
Console.WriteLine("请输入玩家B的姓名");
names[1] = Console.ReadLine();
//判断用户输入的内容是否为空,如果为空,则让用户重新输入
while (names[1] == "" || names[1] == names[0])
{
if (names[1] == "")
{
Console.WriteLine("玩家B的姓名不能为空,请重新输入!");
names[1] = Console.ReadLine();
}
else
{
Console.WriteLine("你输入的姓名与玩家A的姓名{0}相同,请重新输入", names[0]);
names[1] = Console.ReadLine();
}
}
}
static void InitialMap()
{
//用于存储在地图中为地雷的下标
int[] luckyTurn = { 6, 23, 40, 55, 69, 83 };//幸运轮盘 1
int[] landMine = { 5, 13, 17, 33, 38, 50, 64, 80, 94 };//地雷 2
int[] pause = { 9, 27, 60, 93 };//暂停的坐标 3
int[] timeTunnel = { 20, 25, 45, 63, 72, 88, 90 };//时空隧道 4
for (int i = 0; i < 100; i++) // 初始化map数组的数据
map[i] = 0;
//把幸运轮盘位置填入map中
for (int i = 0; i < luckyTurn.Length; i++)
map[luckyTurn[i]] = 1;
//把地雷填入map中
for (int i = 0; i < landMine.Length; i++)
map[landMine[i]] = 2;
//把暂停填入map中
for (int i = 0; i < pause.Length; i++)
map[pause[i]] = 3;
//把时空隧道填入map中
for (int i = 0; i < timeTunnel.Length; i++)
map[timeTunnel[i]] = 4;
}
/// <summary>
/// 获得第pos坐标上应该绘制的图案
/// </summary>
/// <param name="pos">要绘制的坐标</param>
/// <returns></returns>
static string getMapString(int pos)
{
string result = "";
if (playerPos[0] == pos && playerPos[1] == pos)
{
Console.ForegroundColor = ConsoleColor.Yellow;
result = "<>";
}
else if (playerPos[0] == pos)
{
Console.ForegroundColor = ConsoleColor.Yellow;
result = "A";
}
else if (playerPos[1] == pos)
{
Console.ForegroundColor = ConsoleColor.Yellow;
result = "B";
}
else
{
switch (map[pos])
{
case 0:
Console.ForegroundColor = ConsoleColor.White;
result = "□";
break;
case 1:
Console.ForegroundColor = ConsoleColor.Red;
result = "◎";
break;
case 2:
Console.ForegroundColor = ConsoleColor.Green;
result = "☆";
break;
case 3:
Console.ForegroundColor = ConsoleColor.Blue;
result = "▲";
break;
case 4:
Console.ForegroundColor = ConsoleColor.DarkBlue;
result = "卍";
break;
}
}
return result;
}
static void drawMap()
{
Console.WriteLine("图例:幸运轮盘:◎ 地雷:☆ 暂停:▲ 时空隧道:卍 ");
//画第一行
for (int i = 0; i < 30; i++)
Console.Write(getMapString(i));
Console.WriteLine();
//左边的第一列
for (int i = 30; i < 35; i++)
{
for (int j = 0; j < 29; j++)
Console.Write("");
Console.Write(getMapString(i));
Console.WriteLine();
}
//第二行
for (int i = 64; i >= 35; i--)
Console.Write(getMapString(i));
Console.WriteLine();
//右边的列
for (int i = 65; i < 70; i++)
{
Console.Write(getMapString(i));
Console.WriteLine();
}
//第三行
for (int i = 70; i < 100; i++)
Console.Write(getMapString(i));
Console.ResetColor();
Console.WriteLine();
}
static void checkPos()
{
for (int i = 0; i <= 1; i++)
{
if (playerPos[i] > 99)
{
playerPos[i] = 99;
}
if (playerPos[i] < 0)
{
playerPos[i] = 0;
}
}
}
static int ReadInt()//产生一个整数
{
int i = ReadInt(int.MaxValue, int.MinValue);
return i;
}
static int ReadInt(int min, int max)//产生min--max 之间的数
{
while (true)
{
try
{
int number = Convert.ToInt32(Console.ReadLine());
if (number < min || number > max)
{
Console.WriteLine("只能输入{0}--{1}之间的数字,请重新输入", min, max);
continue;
}
return number;
}
catch
{
Console.WriteLine("只能输入数字,请重新输入!");
}
}
}
/// <summary>
/// A或者B掷筛子的方法
/// </summary>
/// <param name="playerNumber">A掷筛子传0过来 B掷筛子传1过来</param>
static void Action(int playerNumber)
{
if (isStop[playerNumber] == false)
{
Console.WriteLine("{0}按任意键开始掷筛子......", names[playerNumber]);
ConsoleKeyInfo sec = Console.ReadKey(true);
step = r.Next(1, 7);//产生一个1到6之间的随机数
if (sec.Key == ConsoleKey.Tab)
{
ConsoleKeyInfo sec1 = Console.ReadKey(true);
if (sec1.Key == ConsoleKey.F1)
{
step = ReadInt(1, 100);
}
}
Console.WriteLine("{0}掷出了{1}", names[playerNumber], step);
Console.WriteLine("{0}按任意键开始行动......", names[playerNumber]);
Console.ReadKey(true);
playerPos[playerNumber] += step; //注意,一旦坐标发生改变,就要判断坐标值是否>99||<0
checkPos();//检查坐标是否越界
if (playerPos[playerNumber] == playerPos[1 - playerNumber]) //玩家A采到玩家B
{
playerPos[1 - playerNumber] = 0;
msg = string.Format("{0}踩到了{1},{1}退回了原点", names[playerNumber], names[1 - playerNumber]);
}
else
{//没踩到,要判断玩家A现在所在的位置是否有其他关卡
switch (map[playerPos[playerNumber]])
{
case 0:
//普通,没有效果
msg = "";
break;
case 1:
//走到了 幸运轮盘关卡
Console.Clear();
Console.WriteLine("你走到了幸运轮盘,请选择运气?");
Console.WriteLine("1 ---交换位置 2---轰炸对方");
int userSelect = ReadInt(1, 2);
if (userSelect == 1)
{//要与对方交换位置
int temp = playerPos[playerNumber];
playerPos[playerNumber] = playerPos[1 - playerNumber];
playerPos[1 - playerNumber] = temp;
msg = string.Format("{0}选了与对方交换位置", names[playerNumber]);
}
else
{//轰炸对方
playerPos[1 - playerNumber] -= 6;
msg = string.Format("{0}轰炸了{1},{1}退回了6格", names[playerNumber], names[1 - playerNumber]);
checkPos();
}
break;
case 2:
//踩到了地雷
playerPos[playerNumber] -= 6;
checkPos();
msg = string.Format("{0}踩到了地雷,{0}退了6格", names[playerNumber]);
break;
case 3:
//暂停一次
isStop[playerNumber] = true;
msg = string.Format("{0}走到了红灯,下次暂停一次啊", names[playerNumber]);
break;
case 4:
//踩到时空隧道
playerPos[playerNumber] += 10;
msg = string.Format("{0}进入了时空隧道, * 了,进了10格", names[playerNumber]);
break;
}
}
}
else
{
isStop[playerNumber] = false;
}
if (playerPos[playerNumber] >= 99)
{
//判断谁胜利,谁失败
Console.Clear();
if (playerPos[0] >= 99)
{
Console.WriteLine("{0}胜利了!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", names[0]);
}
else
{
Console.WriteLine("{0}胜利了!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!", names[1]);
}
}
Console.Clear();
drawMap();
if (msg != "")
{
Console.WriteLine(msg);
}
Console.WriteLine("{0}掷出了{1},行动完成!", names[playerNumber], step);
Console.WriteLine("*************玩家A和玩家B的位置*********");
Console.WriteLine("{0}的位置为:{1}", names[0], playerPos[0] + 1);
Console.WriteLine("{0}的位置为:{1}", names[1], playerPos[1] + 1);
}
}
}


猜你喜欢
- 前言你是否在onStart()启动过某项任务却忘记在onStop()中取消呢?人不是机器,难免会有错漏。就算老手不会犯错,也不能保证新人不会
- 递归三要素:1、明确递归终止条件;2、给出递归终止时的处理办法;3、提取重复的逻辑,缩小问题规模。1、1+2+3+…+nimport jav
- 目录1.项目gitthub地址链接: https://github.com/baisul/generateCode.git切换到master
- 进度条样式在项目中经常可以见到,下面小编给大家分享Android三种方式实现ProgressBar自定义圆形进度条。Android进度条有4
- sql语句CDATA标签的用法CDATA 指的是不应由 XML 解析器进行解析的文本数据(Unparsed Character Data)。
- 话不多说,上代码: /** * 获取字符串的长度,如果有中文,则每个中文字符计为2位 * @param value
- Android Notification使用详解Notification核心代码(链式调用):适用于Android 4.0以上(
- 封面图下个季度的目标是把前端监控相关的内容梳理出来,梳理出来之后可能会在公司内部做个分享~Flutter应用程序既括代码也包括一些其他的资产
- 正文关于Java中的 * ,我们首先需要了解的是一种常用的设计模式--代理模式,而对于代理,根据创建代理类的时间点,又可以分为静态代理和动
- 本文实例讲述了Java基于servlet * 实现在线人数监控功能的方法。分享给大家供大家参考,具体如下:1、分析:做一个网站在线人数统计,
- Intellij IDEA 公司 JetBrains 推出了一种新字体:JetBrains Mono,它是专为开发人员设计的。为什么说它是专
- 多层嵌套JSON类型数据解析简单来说:“key”:“value&rdqu
- 对 Debug 的好奇初学 Java 时,我对 IDEA 的 Debug 非常好奇,不止是它能查看断点的上下文环境,更神奇的是我可以在断点处
- 应用启动的时候有短暂的白屏,如图:可以通过设置theme的方式来解决 <style name="AppTheme"
- Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,是一种比较常用
- 前言说起Android进行间通信,大家第一时间会想到AIDL,但是由于Binder机制的限制,AIDL无法传输超大数据。那么我们如何在进程间
- MyBatis添加记录后获取主键ID,这是一个很常见的需求。这个需求有分为两种情况:(1)添加单条记录时获取主键值;(2)获取批量添加记录时
- newInstance()使用类加载机制,new是创建一个新类。从JVM角度看,使用new创建一个类的时候,这个类可以没有被加载。但是使用n
- Java代码1. ReentrantLock加锁阻塞,一个condition对应一个线程,以便于唤醒时使用该condition一定会唤醒该线
- 今天在项目中用到了用到了一种特殊的EditText,当用户在EditText中输入内容,点击搜索按钮的时候,输入的内容能够高亮,然后添加到输