基本信息
源码名称:c语言小游戏源码(华容道)
源码大小:2.59KB
文件格式:.c
开发语言:C/C++
更新时间:2018-05-27
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 7 元×
微信扫码支付:7 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
见截图
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#include <windows.h>
int c=0,a[8][8]= {0},n=0,x,y,b[8][8]= {0};
int t=0;
int main() {
T1:
system("color 0f");
srand(time(0));
printf("■ ■☆步 数:%d\n■ ■☆操作方法:\n■ ■☆输入数字移动滑块,3~6选择难度 \n■ ■☆关 于:\n■ ■☆华容道V1.0\n■ ■☆作者:根根本根\n",c);
printf("☆☆☆☆☆☆☆☆☆☆☆");
printf("■■■■■■■■■■■■☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
scanf("%d",&n);
if(n==0) {
return 0;
}
for(int i=1; i<n*n; i ) {
y=rand()%n 1;
x=rand()%n 1;
if(a[x][y]!=0) {
i--;
} else {
a[x][y]=i;
}
}
for(int i=1; i<=n; i ) {
for(int j=1; j<=n; j ) {
printf("%2d ",a[i][j]);
}
printf("\n");
}
while(t==0) {
int v=0,st=n*n;
char e;
e=getch();
for(int i=1; i<=n; i ) {
for(int j=1; j<=n; j ) {
if(a[i][j]==0) {
switch(e) {//up=72,down=80,right=77,left=75
case 72:
a[i][j]=a[i 1][j];
a[i 1][j]=0;
break;
case 80:
a[i][j]=a[i-1][j];
a[i-1][j]=0;
break;
case 75:
a[i][j]=a[i][j 1];
a[i][j 1]=0;
break;
case 77:
a[i][j]=a[i][j-1];
a[i][j-1]=0;
break;
}
v=1;
break;
}
}
if(v) {
break;
}
}
// if(a[x 1][y]==0) {
// a[x 1][y]=e;
// a[x][y]=0;
// } else if(a[x][y 1]==0) {
// a[x][y 1]=e;
// a[x][y]=0;
// } else if(a[x-1][y]==0) {
// a[x-1][y]=e;
// a[x][y]=0;
// } else if(a[x][y-1]==0) {
// a[x][y-1]=e;
// a[x][y]=0;
// }
c ;
system("cls");
printf("■ ■☆步 数:%d\n■ ■☆操作方法:\n■ ■☆输入数字移动滑块,3~6选择难度 \n■ ■☆关 于:\n■ ■☆华容道V1.0\n■ ■☆作者:根根本根\n",c);
printf("☆☆☆☆☆☆☆☆☆☆☆");
printf("■■■■■■■■■■■■☆☆☆☆☆☆☆☆☆☆☆☆☆\n");
for(int i=1; i<=n; i ) {
for(int j=1; j<=n; j ) {
printf("%2d ",a[i][j]);
}
printf("\n");
}
if(a[n][n]!=0) {
continue;
}
t=1;
for(int i=1; i<=n; i ) {
for(int j=1; j<=n; j ) {
if(a[i][j]!=(i-1)*n j&&(i!=n||j!=n)) {
t=0;
break;
}
}
if(t==0) {
break;
}
}
}
system("cls");
printf("恭喜你你用了%d步完成了%d阶华容道!\n想再来一局按空格\n",c/2,n);
char z=getchar();
if(z==' ') {
system("cls");
goto T1;
}
Sleep(3000);
return 0;
}