感谢格致杭业晟同学改进完善

uses crt;
var
  i,j,k,ls,x,y:byte;
  b:array[0..11,0..11] of shortint;
  f:array[0..11,0..11] of boolean;
  c:char;
procedure a;  //光标往左
begin
  gotoxy((x+2)*2,y+3);  //恢复上一个位置
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  if x=0 then x:=9
         else x:=x-1;
  textbackground(white);  //更新新位置
  textcolor(black);
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  textbackground(black);
  textcolor(white);
end;
procedure w;
begin
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  if y=0 then y:=9
         else y:=y-1;
  textbackground(white);
  textcolor(black);
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  textbackground(black);
  textcolor(white);
end;
procedure d;
begin
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  if x=9 then x:=0
         else x:=x+1;
  textbackground(white);
  textcolor(black);
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  textbackground(black);
  textcolor(white);
end;
procedure s;
begin
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  if y=9 then y:=0
         else y:=y+1;
  textbackground(white);
  textcolor(black);
  gotoxy((x+2)*2,y+3);
  if f[y+1,x+1] then write(b[y+1,x+1])
                else write('?');
  textbackground(black);
  textcolor(white);
end;
begin
  clrscr;
  cursoroff;
  fillchar(f,sizeof(f),false);
  randomize;
  for i:=1 to 10 do  //随机生成地雷(10%,-1表示地雷格),并统计地雷个数
    for j:=1 to 10 do begin
      k:=random(10);
      if k=0 then b[i,j]:=-1
             else b[i,j]:=0;
      if b[i,j]=-1 then inc(ls);
    end;

for i:=1 to 10 do  //计算非地雷格周边的地雷数
    for j:=1 to 10 do
      if b[i,j]=0 then begin
        if b[i-1,j-1]=-1 then inc(b[i,j]);
        if b[i-1,j]=-1 then inc(b[i,j]);
        if b[i-1,j+1]=-1 then inc(b[i,j]);
        if b[i,j-1]=-1 then inc(b[i,j]);
        if b[i,j+1]=-1 then inc(b[i,j]);
        if b[i+1,j-1]=-1 then inc(b[i,j]);
        if b[i+1,j]=-1 then inc(b[i,j]);
        if b[i+1,j+1]=-1 then inc(b[i,j]);
      end;
  writeln('   0 1 2 3 4 5 6 7 8 9');  //输出初始界面
  writeln(' .--------------------.');
  for i:=1 to 10 do begin
    write(i-1,'|');
    for j:=1 to 10 do write(' ?');
    write('|');
    writeln;
  end;
  writeln(' .-------------------.');

x:=0;  //光标定位到左上角
  y:=0;
  textbackground(white);
  textcolor(black);
  gotoxy((x+2)*2,y+3);
  write('?');
  textbackground(black);
  textcolor(white);
  while (100-ls)>0 do  //扫雷开始
    if keypressed then begin
      c:=readkey;
      if c='w' then w;
      if c='a' then a;
      if c='s' then s;
      if c='d' then d;
      if c=' ' then  //如果按空格
        if b[y+1,x+1]=-1 then begin  //如果这格是地雷
          clrscr;
          textcolor(lightred);
          writeln('Bomb! You Lose!');
          writeln('Press Enter to Exit');
          readln;
          exit;
        end
        else begin  //如果这格不是地雷
          textbackground(white);
          textcolor(black);
          gotoxy((x+2)*2,y+3);
          write(b[y+1,x+1]);
          textbackground(black);
          textcolor(white);
          f[y+1,x+1]:=true;
          inc(ls);
        end;
  end;
  clrscr;
  textcolor(yellow);
  writeln('You Win!');
  writeln('Press Enter to Exit');
  readln;
end.

扫地雷II的更多相关文章

  1. Pascal语言(存档)

    数据类型 标准函数 运算符和表达式 输入语句 输出语句 if语句 case语句 for语句 while语句 repeat语句 函数与过程 形参与实参 全局变量与局部变量 数组 字符串 枚举 子界 集合 ...

  2. [SDFZOJ]1069:树上统计

    神题...std丑的不行. 我们可以发现i->i+1的边被覆盖过i×(n-i)次. 因为以1->i为左端点,以i+1->n的为右端点,i->i+1都将被覆盖这么多次. 然后从1 ...

  3. 洛谷P1372 又是毕业季I&&P1414 又是毕业季II[最大公约数]

    P1372 又是毕业季I 题目背景 “叮铃铃铃”,随着高考最后一科结考铃声的敲响,三年青春时光顿时凝固于此刻.毕业的欣喜怎敌那离别的不舍,憧憬着未来仍毋忘逝去的歌.1000多个日夜的欢笑和泪水,全凝聚 ...

  4. Android安全开发之WebView中的地雷

    Android安全开发之WebView中的地雷 0X01 About WebView 在Android开发中,经常会使用WebView来实现WEB页面的展示,在Activiry中启动自己的浏览器,或者 ...

  5. [LeetCode] Palindrome Partitioning II 解题笔记

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

  6. LeetCode :Word Ladder II My Solution

    Word Ladder II Total Accepted: 11755 Total Submissions: 102776My Submissions Given two words (start  ...

  7. 2020: [Usaco2010 Jan]Buying Feed, II

    2020: [Usaco2010 Jan]Buying Feed, II Time Limit: 3 Sec  Memory Limit: 64 MBSubmit: 220  Solved: 162[ ...

  8. [leetcode]Weekly Contest 68 (767. Reorganize String&&769. Max Chunks To Make Sorted&&768. Max Chunks To Make Sorted II)

    766. Toeplitz Matrix 第一题不说,贼麻瓜,好久没以比赛的状态写题,这个题浪费了快40分钟,我真是...... 767. Reorganize String 就是给你一个字符串,能不 ...

  9. LeetCode: Jump Game II 解题报告

    Jump Game II Given an array of non-negative integers, you are initially positioned at the first inde ...

随机推荐

  1. iOS开发UI篇—ios应用数据存储方式(归档)

    iOS开发UI篇—ios应用数据存储方式(归档)  一.简单说明 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦: 偏好设置(将所有的东西都保存在同 ...

  2. mysql命令行创建存储过程命令行定时执行sql语句

    mysql -uroot -p show databases; use scm; show tables; show procedure status; 其他命令: SHOW VARIABLES LI ...

  3. Invalid byte 3 of 3-byte UTF-8 sequence

    用maven编译,tomcat启动时报错:IOException parsing XML document from class path resource [applicationContext.x ...

  4. iOS开发:XCTest单元测试(附上一个单例的测试代码)

    测试驱动开发并不是一个很新鲜的概念了.在我最开始学习程序编写时,最喜欢干的事情就是编写一段代码,然后运行观察结果是否正确.我所学习第一门语言是c语言,用的最多的是在算法设计上,那时候最常做的事情就是编 ...

  5. androidTV第一次创建(转:支持原创)

    转载地址:http://blog.csdn.net/aa2967277/article/details/50617677 AndroidTV应用开发简介 目前,网上还没有对AndroidTV的足够的介 ...

  6. Objective-C学习笔记-第一天(3)

    话不多说,学了这么多,写个快速排序先. 除了快排,以后有时间还要加堆排.归并等等. 今天学了有,类.协议.语法. 因为算法类,不止一个算法.所以新建一个Algorithm(算法)协议: #import ...

  7. Linux type命令

    用途说明 type命令用来显示指定命令的类型.一个命令的类型可以是如下几种: alias 别名 keyword 关键字,Shell保留字 function 函数,Shell函数 builtin 内建命 ...

  8. UIkit框架之UISegmentedControl

    1.继承链:UIcontrol:UIview:uiresponder:NSObject 2.初始化 (1)- (instancetype)initWithItems:(NSArray *)items ...

  9. Cfree

    #include<stdio.h>int main(){ printf("Hello World!!!/n"); return 0;} #include<stdi ...

  10. python模块之collections

    我们都知道,Python拥有一些内置的数据类型,比如str, int, list, tuple, dict等, collections模块在这些内置数据类型的基础上,提供了几个额外的数据类型: (1) ...