C语言实现COLOR LINEZ游戏

预处理部分
==============================================================================*/

#define NEO_temp_dir_unused
#define BOARD_COLOR 7

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "neo.h"

/*==============================================================================
全局变量部分
==============================================================================*/

char chesscolor[9][9]={0}; /* 定义棋盘棋子颜色 */
char chessboard[9][9]; /* 定义棋盘空位 */
long grade=0; /* 分数 */

/*==============================================================================
函数部分
==============================================================================*/
/*==============================================================================
检查棋盘是否已满 满返回1,不满返回0.
==============================================================================*/

int boardfull(void) {
  int i,t; /* 临时计数 */
  for(i=0;i<9;i++)
    for(t=0;t<9;t++) if(chessboard[i][t]==1) return 0;
  return 1;
}

/*==============================================================================
随机生成棋子.
==============================================================================*/

void buildchess(void) {
  int x,y;
  do {
    x=rand()%9;
    y=rand()%9;
  }while(chesscolor[y][x]!=0);
  chesscolor[y][x]=rand()%7+1;
  chessboard[y][x]=0;
  delchess(y,x);
}

/*==============================================================================
绘制整个棋盘(包括棋子).
==============================================================================*/

void drawboard(void) {
  int i,t; /* 临时计数 */
  for(i=20;i<420;i+=40) hline(20,i,380,BOARD_COLOR);
  for(i=20;i<420;i+=40) vline(i,20,380,BOARD_COLOR);
  for(i=0;i<9;i++)
    for(t=0;t<9;t++)
      circlefill(t*40+40,i*40+40,12,chesscolor[i][t]);
}

/*==============================================================================
判断位于第x行,y列的棋子是否能移动到第to_x行,to_y列,可以返回1,否则返回0.
==============================================================================*/

int canmove(int x,int y,int to_x,int to_y) {
  if(x==to_x && y==to_y) return 1;
  chessboard[x][y]=0;
  if(chessboard[x+1][y] && x<8)
    if(canmove(x+1,y,to_x,to_y)) {
      chessboard[x][y]=1;
      return 1;
    }
  if(chessboard[x-1][y] && x>0)
    if(canmove(x-1,y,to_x,to_y)) {
      chessboard[x][y]=1;
      return 1;
    }
  if(chessboard[x][y+1] && y<8)
    if(canmove(x,y+1,to_x,to_y)) {
      chessboard[x][y]=1;
      return 1;
    }
  if(chessboard[x][y-1] && y>0)
    if(canmove(x,y-1,to_x,to_y)) {
      chessboard[x][y]=1;
      return 1;
    }
  chessboard[x][y]=1;
  return 0;
}

/*==============================================================================
判断新增棋子后是否可以消去棋子,可以则消去并返回1,否则返回0.
==============================================================================*/

int delchess(int x,int y) {
  int i,j; /* 临时计数 */
  int sum=0;
  /* 消除竖行 */
  for(i=x;i<9;i++) {
    if(chesscolor[x][y]!=chesscolor[i][y]) break;
    sum++;
  }
  for(i=x;i>-1;i--) {
    if(chesscolor[x][y]!=chesscolor[i][y]) break;
    sum++;
  }
  if(sum>5) {
    for(i=x+1;i<9;i++) {
      if(chesscolor[x][y]!=chesscolor[i][y]) break;
      chesscolor[i][y]=0;
      chessboard[i][y]=1;
    }
    for(i=x-1;i>-1;i--) {
      if(chesscolor[x][y]!=chesscolor[i][y]) break;
      chesscolor[i][y]=0;
      chessboard[i][y]=1;
    }
    chesscolor[x][y]=0;
    chessboard[x][y]=1;
    return 1;
  }
  sum=0;
  /* 消除横行 */
  for(i=y;i<9;i++) {
    if(chesscolor[x][y]!=chesscolor[x][i]) break;
    sum++;
  }
  for(i=y;i>-1;i--) {
    if(chesscolor[x][y]!=chesscolor[x][i]) break;
    sum++;
  }
  if(sum>5) {
    for(i=y+1;i<9;i++) {
      if(chesscolor[x][y]!=chesscolor[x][i]) break;
      chesscolor[x][i]=0;
      chessboard[x][i]=1;
    }
    for(i=y-1;i>-1;i--) {
      if(chesscolor[x][y]!=chesscolor[x][i]) break;
      chesscolor[x][i]=0;
      chessboard[x][i]=1;
    }
    chesscolor[x][y]=0;
    chessboard[x][y]=1;
    return 1;
  }
  sum=0;
  /* 消除斜行( \) */
  for(i=x,j=y;(i<9)&&(j<9);i++,j++) {
    if(chesscolor[x][y]!=chesscolor[i][j]) break;
    sum++;
  }
  for(i=x,j=y;(i>-1)&&(j>-1);i--,j--) {
    if(chesscolor[x][y]!=chesscolor[i][j]) break;
    sum++;
  }
  if(sum>5) {
    for(i=x+1,j=y+1;(i<9)&&(j<9);i++,j++) {
      if(chesscolor[x][y]!=chesscolor[i][j]) break;
      chesscolor[i][j]=0;
      chessboard[i][j]=1;
    }
    for(i=x-1,j=y-1;(i>-1)&&(j>-1);i--,j--) {
      if(chesscolor[x][y]!=chesscolor[i][j]) break;
      chesscolor[i][j]=0;
      chessboard[i][j]=1;
    }
    chesscolor[x][y]=0;
    chessboard[x][y]=1;
    return 1;
  }
  sum=0;
  /* 消除斜行( / ) */
  for(i=x,j=y;(i<9)&&(j>-1);i++,j--) {
    if(chesscolor[x][y]!=chesscolor[i][j]) break;
    sum++;
  }
  for(i=x,j=y;(i>-1)&&(j<9);i--,j++) {
    if(chesscolor[x][y]!=chesscolor[i][j]) break;
    sum++;
  }
  if(sum>5) {
    for(i=x+1,j=y-1;(i<9)&&(j>-1);i++,j--) {
      if(chesscolor[x][y]!=chesscolor[i][j]) break;
      chesscolor[i][j]=0;
      chessboard[i][j]=1;
    }
    for(i=x-1,j=y+1;(i>-1)&&(j<9);i--,j++) {
      if(chesscolor[x][y]!=chesscolor[i][j]) break;
      chesscolor[i][j]=0;
      chessboard[i][j]=1;
    }
    chesscolor[x][y]=0;
    chessboard[x][y]=1;
    return 1;
  }
  return 0;
}

/*==============================================================================
移动棋子.
==============================================================================*/

void movechess(void) {
  int mousex,mousey;
  int mousetox,mousetoy;
  while(1) {
    scare_mouse();
    drawboard(); /* 绘制棋盘 */
    rectfill(0,0,640,16,0);
    neo_printf(0,0,"当前分数:%ld",grade);
    unscare_mouse();
    while(get_click_info()!=8) ;
    mousex=get_mouse_x();
    mousey=get_mouse_y();
    if(mousex<=20 || mousex>=380) continue;
    if(mousey<=20 || mousey>=380) continue;
    mousex=(mousex-20)/40;
    mousey=(mousey-20)/40;
    if(chessboard[mousey][mousex]==1) continue;
    rect(mousex*40+20,mousey*40+20,mousex*40+60,mousey*40+60,4);
    while(get_click_info()!=8) ;
    mousetox=get_mouse_x();
    mousetoy=get_mouse_y();
    if(mousetox<=20 || mousetox>=380) continue;
    if(mousetoy<=20 || mousetoy>=380) continue;
    mousetox=(mousetox-20)/40;
    mousetoy=(mousetoy-20)/40;
    if(chessboard[mousetoy][mousetox]==0) continue;

    if(canmove(mousey,mousex,mousetoy,mousetox)) {
      chessboard[mousetoy][mousetox]=0;
      chessboard[mousey][mousex]=1;
      chesscolor[mousetoy][mousetox]=chesscolor[mousey][mousex];
      chesscolor[mousey][mousex]=0;
      if(delchess(mousetoy,mousetox)) {
        grade+=10;
        continue;
      }
    } else continue;
    break;
  }
}

/*==============================================================================
主函数.
==============================================================================*/

int main(void) {
  int i; /* 临时计数 */
  int n=3;
  neo_init(); /* 初始化NEO库 */
  set_video_mode(640,480,8,0,0); /* 640X480X64K模式 */
  install_keyboard(); /* 加载高级键盘 */
  _install_timer(); /* 加载时钟 */
  change_timer(500); /* 改变(时钟频率)鼠标刷新频率为500次/秒 */
  install_mouse(); /* 加载高级鼠标 */
  srand(100); /* 初始化随机函数 */

  memset(chessboard,1,sizeof(chessboard));

  for(i=0;i<n;i++) buildchess();
  while(!boardfull()) {
    movechess();
    for(i=0;i<n;i++) if(!boardfull()) buildchess();
  }
  scare_mouse();
  drawboard(); /* 绘制棋盘 */
  rectfill(0,0,640,16,0);
  neo_printf(0,0,"游戏结束,你的最终得分:%ld,谢谢你的使用",grade);
  _getch();
  return 0;
}

时间: 2024-08-29 14:49:12

C语言实现COLOR LINEZ游戏的相关文章

malloc-关于c语言的贪吃蛇游戏问题,为什么最后编译出错?

问题描述 关于c语言的贪吃蛇游戏问题,为什么最后编译出错? /* c语言之贪吃蛇 */ #include #include #include #include #include #include #define N 24 int apple[3]; //食物 char score[3]; //分数 char tail [3];//蛇尾前面一节 //输出坐标 void gotoxy(int x,int y) { COORD pos; pos.X=x; pos.Y=y; SetConsoleCurs

c语言之贪吃蛇游戏,为什么最后运行时没有苹果出现?求助大神!!!

问题描述 c语言之贪吃蛇游戏为什么最后运行时没有苹果出现求助大神 /* c语言之贪吃蛇 */ #include #include #include #include #include #include #define N 21 int apple[3]; //食物 char score[3]; //分数 char tail [3];//蛇尾前面一节 //输出坐标 void gotoxy(int x,int y) { COORD pos; pos.X=x; pos.Y=y; SetConsoleC

怎样用C语言编写一个迷宫游戏,能否再进一步使迷宫可以自主变换

问题描述 怎样用C语言编写一个迷宫游戏,能否再进一步使迷宫可以自主变换 就是用c语言实现一个迷宫游戏,如果可以的话能否在加一个条件就是:比如每走10步迷宫就会发生一定的变化,当然一定要能走出去,如果走不出去也就没意义了 解决方案 动态变化的话,想象是蛮复杂的,得用点动态规划什么的算法吧,没有涉及过,期待大神

c语言有关于纸牌游戏的字符串识别问题

问题描述 c语言有关于纸牌游戏的字符串识别问题 有关字符串识别的问题,实在不明白应该是什么思路,求思路,最好有代马,跪谢!!! 解决方案 首先把字符串放到一个数组里面,字母全部用数字代替.遍历数组,全部异或,得到数值再挨个与数组中的数字对比,如果有相等,就是二对. 解决方案二: 加个变量记着...

C语言吃金豆游戏的源代码

问题描述 C语言吃金豆游戏的源代码 我那个吃金豆游戏总是运行不了,请问大神有木有吃金豆的c语言程序源代码 解决方案 吃金豆游戏的源代码捡金豆游戏源代码 解决方案二: 你要什么平台的这个源码 解决方案三: 天知道你说的是什么代码,怎么运行不了,运行不了是程序的问题还是你的问题.

eclipse-我有一个用java语言编写的拼图游戏的文件压缩包,怎样有Eclipse打开并运行?

问题描述 我有一个用java语言编写的拼图游戏的文件压缩包,怎样有Eclipse打开并运行? 我有一个用java语言编写的拼图游戏的文件压缩包,怎样有Eclipse打开并运行? 解决方案 1.将压缩包解压 2.打开Eclipse, 3.在左侧工作区右键Import-General-Existing Projects into Workspaces 4.next,finish

c语言程序猜数字游戏程序

问题描述 c语言程序猜数字游戏程序 #include #include #include #include #include int main(void) { unsigned int max = 3; unsigned int guess = 0; unsigned int chones = 0; unsigned int limit = 20; char answer = 'n'; printf("这是一个猜数字游戏!游戏开始时! "); srand(time(NULL)); wh

java-关于用Java语言编写连连看小游戏

问题描述 关于用Java语言编写连连看小游戏 我要做一个连连看程序,用JAVA语言编写,请问有没有大神手里有源码或是能抽空回答我编写过程中的问题,谢 解决方案 http://download.csdn.net/album/detail/1369 有你需要的游戏 都是源码

java-关于用Java语言编写连连看小游戏的问题

问题描述 关于用Java语言编写连连看小游戏的问题 用Java语言编写连连看小游戏时,如何加入炸弹和计时器功能,怎样才能在点击再来一局是把已得分数归零 解决方案 计时器可以开线程,清零不就把记录分数值的变量赋零不就好了 解决方案二: java游戏源码 很多游戏http://download.csdn.net/album/detail/1369