本文目錄一覽:
求2048遊戲C語言code!
我還真有個 這是個VC版的 網上找的 我只是搬運工 Linux版本的有點麻煩,用的ncurse。如果要的話我再給
#include stdio.h
#include stdlib.h
#include time.h
#include conio.h
#include string.h
int MAP[4][4],gre;
int add(int n)
{
int num = rand();
int tf = num % 2;
int x,y,i;
x = num % 4;
srand((unsigned int)time(0));
srand((unsigned int)time(0) + (unsigned int)num);
y = rand();
y %= 4;
if (tf)
num = 2;
else
num = 4;
if (n == 0)
{
MAP[x][y] = num;
}
else if (n == 1)
{
if (MAP[3][y] == 0)
MAP[3][y] = num;
else
for (i = 0; i 4; i++)
if (MAP[3][i] == 0)
{
MAP[3][i] = num;
break;
}
}
else if (n == 2)
{
if (MAP[0][y] == 0)
MAP[0][y] = num;
else
for (i = 0; i 4; i++)
if (MAP[0][i] == 0)
{
MAP[0][i] = num;
break;
}
}
else if (n == 3)
{
if (MAP[x][3] == 0)
MAP[x][3] = num;
else
for (i = 0; i 4; i++)
if (MAP[i][3] == 0)
{
MAP[i][3] = num;
break;
}
}
else if (n == 4)
{
if (MAP[x][0] == 0)
MAP[x][0] = num;
else
for (i = 0; i 4; i++)
if (MAP[i][0] == 0)
{
MAP[i][0] = num;
break;
}
}
}
int movup(void)
{
int i,k,t;
int tf = 0;
for (k = 0; k 4; k++)
{
int n = 4;
while (n–)
for (i = 0; i 3; i++)
if (MAP[i][k] == 0)
{
for (t = i; t 3; t++)
{
MAP[t][k] = MAP[t + 1][k];
MAP[t + 1][k] = 0;
tf = 1;
}
}
for (i = 0; i 3; i++)
{
if (MAP[i][k] == MAP[i + 1][k])
{
MAP[i][k] *= 2;
gre += MAP[i][k];
if (MAP[i][k] == 2048)
return 0;
for (t = i + 1; t 3; t++)
{
MAP[t][k] = MAP[t + 1][k];
MAP[t + 1][k] = 0;
tf = 1;
}
}
}
}
if (tf)
add(1);
return 1;
}
int movdow(void)
{
int i,k,t;
int tf = 0;
for (k = 0; k 4; k++)
{
int n = 4;
while (n–)
for (i = 3; i 0; i–)
if (MAP[i][k] == 0)
{
for (t = i; t 0; t–)
{
MAP[t][k] = MAP[t – 1][k];
MAP[t – 1][k] = 0;
tf = 1;
}
}
for (i = 3; i 0; i–)
{
if (MAP[i][k] == MAP[i – 1][k])
{
MAP[i][k] *= 2;
gre += MAP[i][k];
if (MAP[i][k] == 2048)
return 0;
for (t = i – 1; t 0; t–)
{
MAP[t][k] = MAP[t – 1][k];
MAP[t – 1][k] = 0;
tf = 1;
}
}
}
}
if (tf)
add(2);
return 1;
}
int movlif(void)
{
int i,k,t;
for (i = 0; i 4; i++)
{
int n = 4;
while (n–)
for (k = 0; k 3; k++)
{
if(MAP[i][k] == 0)
for (t = k; t 3; t++)
{
MAP[i][t] = MAP[i][t + 1];
MAP[i][t + 1] = 0;
}
}
for (k = 0;k 3;k++)
{
if (MAP[i][k] == MAP[i][k + 1])
{
MAP[i][k] *= 2;
gre += MAP[i][k];
if (MAP[i][k] == 2048)
return 0;
for (t = k + 1; t 3; t++)
{
MAP[i][t] = MAP[i][t + 1];
MAP[i][t + 1] = 0;
}
}
}
}
add(3);
return 1;
}
int movri(void)
{
int i,k,t;
for (i = 0; i 4; i++)
{
int n = 4;
while (n–)
for (k = 3; k 0; k–)
{
if(MAP[i][k] == 0)
for (t = k; t 0; t–)
{
MAP[i][t] = MAP[i][t – 1];
MAP[i][t – 1] = 0;
}
}
for (k = 3;k 0;k–)
{
if (MAP[i][k] == MAP[i][k – 1])
{
MAP[i][k] *= 2;
gre += MAP[i][k];
if (MAP[i][k] == 2048)
return 0;
for (t = k – 1; t 0; t–)
{
MAP[i][t] = MAP[i][t – 1];
MAP[i][t – 1] = 0;
}
}
}
}
add(4);
return 1;
}
int mov(void)
{
char key;
int tf = 1;
fflush(stdin);
key = getch();
if (key == 72)
tf = movup();
else if (key == 80)
tf = movdow();
else if (key == 75)
tf = movlif();
else if (key == 77)
tf = movri();
if (!tf)
{
system(“CLS”);
printf (“恭喜達到2048!\n”);
}
return tf;
}
int pd (void)
{
int i,k;
for (i = 0; i 4; i++)
{
for (k = 1; k 4; k++)
if (MAP[i][k – 1] == MAP[i][k])
return 0;
}
for (i = 0; i 4; i++)
{
for (k = 1; k 4; k++)
if (MAP[k – 1][i] == MAP[k][i])
return 0;
}
system(“CLS”);
printf (“遊戲結束!\n”);
return 1;
}
int pri (void)
{
printf (“得分:%d\n”,gre);
printf (“\t┏━━┳━━┳━━┳━━┓\n”);
printf (“\t┃%4d┃%4d┃%4d┃%4d┃\n”,MAP[0][0],MAP[0][1],MAP[0][2],MAP[0][3]);
printf (“\t┣━━╋━━╋━━╋━━┫\n”);
printf (“\t┃%4d┃%4d┃%4d┃%4d┃\n”,MAP[1][0],MAP[1][1],MAP[1][2],MAP[1][3]);
printf (“\t┣━━╋━━╋━━╋━━┫\n”);
printf (“\t┃%4d┃%4d┃%4d┃%4d┃\n”,MAP[2][0],MAP[2][1],MAP[2][2],MAP[2][3]);
printf (“\t┣━━╋━━╋━━╋━━┫\n”);
printf (“\t┃%4d┃%4d┃%4d┃%4d┃\n”,MAP[3][0],MAP[3][1],MAP[3][2],MAP[3][3]);
printf (“\t┗━━┻━━┻━━┻━━┛\n”);
}
int main()
{
int i;
char s[100];
system(“COLOR 5F”);
printf (“\n\t【2048】控制台版\n\n”);
printf (“遊戲規則(如同名手游):\n”);
printf (“\t開始方格內會出現2或者4等這兩個小數字,\n”);
printf (“\t玩家只需要上下左右(方向鍵控制)其中一個方向來移動出現的數字,\n”);
printf (“\t所有的數字就會向滑動的方向靠攏,\n”);
printf (“\t而滑出的空白方塊就會隨機出現一個數字,\n”);
printf (“\t相同的數字相撞時會疊加靠攏,\n”);
printf (“\t然後一直這樣,不斷的疊加最終拼湊出2048這個數字就算成功。\n”);
printf (“\n\n!輸入任意非零字符開始遊戲!\n(建議將控制台設置為大字體)\n”);
while (scanf (“%s”,s),strcmp(s,”0″))
{
memset (MAP,0,sizeof (MAP));
gre = 0;
system(“CLS”);
add(0);
pri();
while (mov())
{
fflush(stdin);
system(“CLS”);
pri();
if (pd())
break;
}
printf (“按任繼續遊戲!輸入0退出程序!\n”);
}
return 0;
}
關於C語言中 小遊戲2048 的數字移動的問題
很簡單啊,先判斷當前行是否能合併,如果當前行可以合併,就前面補0,
並將後面的數字合併,右移,直到當前這一行不能合併了為止。
C語言里把輸入的2048輸出對應為貳 零 肆 捌
你好:實現的方式有好幾種,可以用if語句,也可以用switch語句。下面用switch演示
#includestdio.h
void
main()
{
char
str[20]={};
int
iValue=0;
printf(“您要輸入幾個數字?\n”);
scanf(“%d”,iValue);
for(int
i
=
;
i
iValue
;
++i)
{
scanf(“%c”,str[i]);
}
switch(str[i])
{
case
0:
printf(“零”);break;
case
2:
printf(“貳”);break;
case
4:
printf(“肆”);break;
case
8:
printf(“捌”);break;
}
}
C語言實現2048遊戲
原文鏈接:
C語言實現2048小遊戲—粵嵌GE6818嵌入式系統實訓 部分功能演示視頻。
實現的全部功能:
1、字模顯示封面組員名字
2、完成2048遊戲在板子上的運行
3、成功或者失敗需要有標誌也可以計分
4、成功或者失敗後可以重新開心
C語言實現2048小遊戲—粵嵌GE6818嵌入式系統實訓—全部功能演示
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/305032.html