zoukankan      html  css  js  c++  java
  • Game2048

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Threading;
    
    namespace SeqListSort
    {
        /// <summary>
        /// <ather>
        /// <lihonglin>
        /// </ather>
        /// <countent>
        /// 2048游戏规则:
      ///开始时棋盘内随机出现两个数字,出现的数字仅可能为2或4
      ///玩家可以选择上下左右四个方向,若棋盘内的数字出现位移或合并,视为有效移动
      ///玩家选择的方向上若有相同的数字则合并,每次有效移动可以同时合并,但不可以连续合并
        ///合并所得的所有新生成数字相加即为该步的有效得分
      ///玩家选择的方向行或列前方有空格则出现位移
      ///每有效移动一步,棋盘的空位(无数字处)随机出现一个数字(依然可能为2或4)
      ///棋盘被数字填满,无法进行有效移动,判负,游戏结束
      ///棋盘上出现2048,判胜,游戏结束
        /// </countent>
        /// </summary>
        //public struct Point
        //{
        //    public int x;
        //    public int y;
        //    public Point(int _x, int _y)
        //    {
        //        this.x = _x;
        //        this.y = _y;
        //    }
        //}
        public enum DIR_TYPE
        {
            TOP,
            LEFT,
            RIGHT,
            BOTTOM
        }
        class Game2048
        {
            const int n = 4;
            static int[,] map = new int[n,n];//定义棋盘
            static int[] temp = new int[n+1];//一个临时数组,存放十六个位置数据
    
            static int score = 0;
            
            static Stack<Point> fullCell = new Stack<Point>();//格子是否已满 这个暂时没有用到,愿意是用它来充当临时数组
    
            public static void GameRandom()
            {
                Random r = new Random();
                int x = 0;
                int y = 0;
                do 
                {
                    x = r.Next(0, n);
                    y = r.Next(0, n);
                } while ( map[x,y] != 0);
                Thread.Sleep(10);
                if (r.Next(0, n + 1) % n == 0)
                {
                    map[x,y] = 4;
                } 
                else
                {
                    map[x, y] = 2;
                }
                fullCell.Push(new Point(x, y));
            }
            public static void GameInit()
            {
                GameRandom();
                GameRandom();
                Display();
            }
            public static void Display()
            {
                Console.WriteLine("分数 = " + score);
                for (int i = 0; i < n; ++i)
                {
                    for (int j = 0; j < n; ++j)
                    {
                        Console.Write("{0,-6}" , map[i, j]);
                    }
                    Console.WriteLine();
                }
                GameOverOrWine();
            }
            public static void GameContral()
            {
                DIR_TYPE type = DIR_TYPE.TOP; 
                while (true)
                {
                    
                    Console.WriteLine("请按w、a、s、d键上下左右控制'0'键退出");
                    char ch = Convert.ToChar(Console.ReadLine());
                    if (ch == 'a'|| ch == 'A' || ch == 'W'|| ch == 'w' || ch == '0'
                        || ch == 'S'|| ch == 's' ||ch == 'D'|| ch == 'd' )
                    {
                        Console.Clear();
                    } 
                    else
                    {
                        Console.WriteLine("按下非法键,请重新按!");
                        continue;
                    }
                    
                    switch (ch)
                    {
                        case '0':
                            {
                                Console.WriteLine("是否退出游戏!(y/n)");
                                ch = Convert.ToChar(Console.ReadLine());
                                if (ch == 'y' || ch == 'Y')
                                {
                                    Environment.Exit(0);
                                }
                                else
                                {
                                    Console.Clear();
                                }
                            }
                            break;
                        case 'A':
                        case 'a':
                            {
                                type = DIR_TYPE.LEFT;
                            }
                            break;
                        case 'D':
                        case 'd':
                            {
                                type = DIR_TYPE.RIGHT;
                            }
                            break;
                        case 'W':
                        case 'w':
                            {
                                type = DIR_TYPE.TOP;
                            }
                            break;
                        case 'S':
                        case 's':
                            {
                                type = DIR_TYPE.BOTTOM;
                            }
                            break;
                    }
                    GameRun(type);
                    Display();
                }
            }
            //玩家可以选择上下左右四个方向,若棋盘内的数字出现位移或合并,视为有效移动
            public static int GameMove( )
            {
                int change = 0;
                int i = 0;
                int j = 0;
                do //去掉中间的0
                {  
                    for (i = 0; i < n; ++i )
                    {
                        if (0 == temp[i])//玩家选择的方向行或列前方有空格则出现位移
                        {
                            if (temp[i] != temp[i + 1])//不相等移动
                            {
                                change = 1;//有效移动
                            }
                            temp[i] = temp[i + 1];
                            temp[i + 1] = 0;
                        }
                    }
                    j++;
                } while (j < n);
    
                for (i = 1; i < n; ++i )
                {
                    //玩家选择的方向上若有相同的数字则合并,每次有效移动可以同时合并,但不可以连续合并
                    if (temp[i] == temp[i - 1])//相同的数字则合并
                    {
                        if (0 != temp[i])
                        {
                            change = 1;
                            score += temp[i];
                        }
                        temp[i - 1] += temp[i - 1];//前一个数字乘自己
                        temp[i] = 0;// 后一个位置 置0    
                    }
                    
                }
                return change;
            }
            public static void GameOverOrWine()
            {
                int count = 0;//记录格子里不为0 的个数
                if (score >= 4096 << 1 )
                {
                    Console.WriteLine("您胜利了 88!");
                    Thread.Sleep(500);
                    Environment.Exit(0);
                }
                else
                {
                    for (int i = 0; i < n; ++i)
                    {
                        for (int j = 0; j < n; ++j)
                        {
                            if ( map[i,j] != 0 )
                            {
                                count++;
                                if ( count == n * n )
                                {
                                    Console.WriteLine("game over");
                                    Thread.Sleep(3000);
                                    Environment.Exit(0);
                                } 
                            }
                            if ( map[i,j] >= 2048 )
                            {
                                Console.WriteLine("您胜利了 88!");
                                Thread.Sleep(500);
                                //Environment.Exit(0);
                            }
                        }
                    }
                }
    
            }
            public static void GameRun(DIR_TYPE type)
            {
                
                int i = 0;
                int j = 0;
                int change = 0;/*判断格子中的数是否改变,0不变*/
                        
                if (type == DIR_TYPE.LEFT || type == DIR_TYPE.RIGHT)
                {
                    for (i = 0; i < n; ++i)
                    {
                        for (j = 0; j < n; ++j)
                        {
                            if (type == DIR_TYPE.LEFT)
                            {
                                temp[j] = map[i, j];//把每一行数据放到临时数组中
                            }
                            else
                            {
                                temp[j] = map[i, 3 - j];
                            }
                        }
                        //temp[4] = 0;
    
                        change += GameMove();//处理每一行数据,进行移除中间的0,合并相同数字,根据change的值可以产生随机数
    
                        for (j = 0; j < n; ++j)
                        {
                            if (type == DIR_TYPE.LEFT)
                            {
                                map[i, j] = temp[j];// 把每一行处理完的数据在放回到地图中
                            }
                            else
                            {
                                map[i, 3 - j] = temp[j];
                            }
                        }
                    }
                }
                else
                {
    
                    for (i = 0; i < n; ++i)
                    {
                        for (j = 0; j < n; ++j)
                        {
    
                            if (type == DIR_TYPE.TOP)
                            {
                                temp[j] = map[j, i];//把每一列数据存进去
                            }
                            else if (type == DIR_TYPE.BOTTOM)
                            {
                                temp[j] = map[3 - j, i];
                            }
    
                        }
                        temp[4] = 0;
                        change += GameMove();
    
                        for (j = 0; j < n; ++j)
                        {
                            if (type == DIR_TYPE.TOP)
                            {
                                map[j, i] = temp[j]; //把处理好的中间变量移回来
                            }
                            else if (type == DIR_TYPE.BOTTOM)
                            {
                                map[3 - j, i] = temp[j];
                            }
                        }
                    }
                }
                
                
                if (change > 0)
                {
                    GameRandom();
                }
            }
        }
    }
  • 相关阅读:
    关于在函数中返回动态的内存
    C与C++中的const
    strcat函数的坑点
    面试题30.最小的k个数
    面试题29.数组中出现次数超过一半的数字
    面试题28.字符串的排列
    面试题27.二叉搜索树与双向链表
    C++中构造函数初始化成员列表总结
    Oracle merge into
    检索 COM 类工厂中 CLSID 解决办法
  • 原文地址:https://www.cnblogs.com/lihonglin2016/p/4307874.html
Copyright © 2011-2022 走看看