鱼C论坛

 找回密码
 立即注册
查看: 1596|回复: 1

[技术交流] 发一个小游戏。

[复制链接]
发表于 2015-1-6 16:39:07 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 kklloo 于 2015-1-6 16:39 编辑

这个是小组里一个学弟写的2048
相信大家都玩过2048八 快来玩玩八
温馨提示:用数字来代替上下左右键 5213分别代表上下左右

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
int num[5][5];          //定义函数和变量 
int score;
void gett(int k);
void up();
void down();
void left();
void right();
void outt();    
void nextt();
void endd();
int main(){             //赋初值
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    int i,j;
    i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    while (num[i][j]!=0){
        i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
        j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    } 
    num[i][j]=2;
    i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    while (num[i][j]!=0){
        i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
        j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    } 
    num[i][j]=2;
    score=0;
    outt();
    endd();
    return 0;
} 
void endd(){
    printf("    2048 mini game    \n");
    printf("                      \n");
    printf("         GAME         \n");
    printf("                      \n");
    printf("         OVER         \n");
    printf("                      \n");
    printf("      YOUR FINAL      \n");
    printf("                      \n");
    printf("    SCORE=%d      \n",score);
    printf("                      \n");
    printf("                      \n");
    printf("    2048 mini game    \n");
}
void outt(){          //输出部分 
    printf("    2048 mini game    \n");
    printf(" score=%d \n",score);
    printf("┌-—┬-—┬-—┬—-┐\n");
    printf("│%3d│%3d│%3d│%3d│\n",num[1][1],num[1][2],num[1][3],num[1][4]);
    printf("├-—┼-—┼—-┼—-┤\n");
    printf("│%3d│%3d│%3d│%3d│\n",num[2][1],num[2][2],num[2][3],num[2][4]);
    printf("├-—┼—-┼—-┼—-┤\n");
    printf("│%3d│%3d│%3d│%3d│\n",num[3][1],num[3][2],num[3][3],num[3][4]);
    printf("├-—┼-—┼-—┼—-┤\n");
    printf("│%3d│%3d│%3d│%3d│\n",num[4][1],num[4][2],num[4][3],num[4][4]);
    printf("└-—┴-—┴—-┴—-┘\n");    
    printf("       By SHIRO-marisa\n");
    int init;
    scanf("%d",&init);
    gett(init);
}
void gett(int k){    //跳转操作 
    if (k==5){up();}
    if (k==2){down();}
    if (k==1){left();}
    if (k==3){right();}

    }
void up(){         //上 
    int i,j,k;
    int zz[5][5];
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=1;
        j=1; 
        while (j<5){
            if (zz[j][i]!=0){
                if (j==4) {num[k][i]=zz[j][i];j++; } 
                    else {
                      if (zz[j][i]==zz[j+1][i]){
                            num[k][i]=zz[j][i]*2;
                         score=zz[j][i]*2+score;
                          k++;
                        j=j+2; 
                      }
                      else {
                          num[k][i]=zz[j][i];
                        j=j+1;
                        k++;
                        }
                 }    
                }
                else j++;
        }
    }
        zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=1;
        j=1; 
        while (j<5){
            if (zz[j][i]!=0){
                if (j==4) {num[k][i]=zz[j][i];j++; } 
                    else {
                      if (zz[j][i]==zz[j+1][i]){
                            num[k][i]=zz[j][i]*2;
                         score=zz[j][i]*2+score;
                          k++;
                        j=j+2; 
                      }
                      else {
                          num[k][i]=zz[j][i];
                        j=j+1;
                        k++;
                        }
                 }    
                }
                else j++;
        }
    }
    system("CLS");
    nextt();
}
void down(){         //下 
    int i,j,k;
    int zz[5][5];
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=4;
        j=4;
        while (j>0){
            if (zz[j][i]!=0){if (j==1) {num[k][i]=zz[j][i];j--; } 
            else {
                      if (zz[j][i]==zz[j-1][i]){
                            num[k][i]=zz[j][i]*2;
                         score=zz[j][i]*2+score;
                          k--;
                        j=j-2; 
                      }
                      else {
                          num[k][i]=zz[j][i];
                        j=j-1;
                        k--;
                        }
                 }    
                }
                else j--;
        } 
    }
        zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=4;
        j=4;
        while (j>0){
            if (zz[j][i]!=0){if (j==1) {num[k][i]=zz[j][i];j--; } 
            else {
                      if (zz[j][i]==zz[j-1][i]){
                            num[k][i]=zz[j][i]*2;
                         score=zz[j][i]*2+score;
                          k--;
                        j=j-2; 
                      }
                      else {
                          num[k][i]=zz[j][i];
                        j=j-1;
                        k--;
                        }
                 }    
                }
                else j--;
        } 
    }
    system("CLS");
    nextt();
} 
void left(){       //左 
    int i,j,k;
    int zz[5][5];
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=1;
        j=1;
        while (j<5){
            if (zz[i][j]!=0){if (j==4) {num[i][k]=zz[i][j];j++; 
            } 
            else {
                      if (zz[i][j]==zz[i][j+1]){
                            num[i][k]=zz[i][j]*2;
                         score=zz[i][j]*2+score;
                          k++;
                        j=j+2; 
                      }
                      else {
                          num[i][k]=zz[i][j];
                        j=j+1;
                        k++;
                        }
                 }    
                }
                else j++;
        } 
    }
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=1;
        j=1;
        while (j<5){
            if (zz[i][j]!=0){if (j==4) {num[i][k]=zz[i][j];j++; 
            } 
            else {
                      if (zz[i][j]==zz[i][j+1]){
                            num[i][k]=zz[i][j]*2;
                         score=zz[i][j]*2+score;
                          k++;
                        j=j+2; 
                      }
                      else {
                          num[i][k]=zz[i][j];
                        j=j+1;
                        k++;
                        }
                 }    
                }
                else j++;
        } 
    }
    system("CLS");
    nextt();
}

void right(){        //右 
    int i,j,k;
    int zz[5][5];
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=4;
        j=4;
        while (j>0){
            if (zz[i][j]!=0){if (j==1) {num[i][k]=zz[i][j];j--; } 
            else {
                      if (zz[i][j]==zz[i][j-1]){
                            num[i][k]=zz[i][j]*2;
                         score=zz[i][j]*2+score;
                          k--;
                        j=j-2; 
                      }
                      else {
                          num[i][k]=zz[i][j];
                        j=j-1;
                        k--;
                        }
                 }    
                }
                else j--;
        } 
    }
    zz[1][1]=0;zz[1][2]=0;zz[1][3]=0;zz[1][4]=0;
    zz[2][1]=0;zz[2][2]=0;zz[2][3]=0;zz[2][4]=0;
    zz[3][1]=0;zz[3][2]=0;zz[3][3]=0;zz[3][4]=0;
    zz[4][1]=0;zz[4][2]=0;zz[4][3]=0;zz[4][4]=0;
    zz[1][1]=num[1][1];zz[1][2]=num[1][2];zz[1][3]=num[1][3];zz[1][4]=num[1][4];
    zz[2][1]=num[2][1];zz[2][2]=num[2][2];zz[2][3]=num[2][3];zz[2][4]=num[2][4];
    zz[3][1]=num[3][1];zz[3][2]=num[3][2];zz[3][3]=num[3][3];zz[3][4]=num[3][4];
    zz[4][1]=num[4][1];zz[4][2]=num[4][2];zz[4][3]=num[4][3];zz[4][4]=num[4][4];
    num[1][1]=0;num[1][2]=0;num[1][3]=0;num[1][4]=0;
    num[2][1]=0;num[2][2]=0;num[2][3]=0;num[2][4]=0;
    num[3][1]=0;num[3][2]=0;num[3][3]=0;num[3][4]=0;
    num[4][1]=0;num[4][2]=0;num[4][3]=0;num[4][4]=0;
    for (i=1;i<=4;i++){
        k=4;
        j=4;
        while (j>0){
            if (zz[i][j]!=0){if (j==1) {num[i][k]=zz[i][j];j--; } 
            else {
                      if (zz[i][j]==zz[i][j-1]){
                            num[i][k]=zz[i][j]*2;
                         score=zz[i][j]*2+score;
                          k--;
                        j=j-2; 
                      }
                      else {
                          num[i][k]=zz[i][j];
                        j=j-1;
                        k--;
                        }
                 }    
                }
                else j--;
        } 
    }
    system("CLS");
    nextt();
}
void nextt(){       //随机生成新方块 开始下一次 
    srand((int)time(0));
    int i,j,k;
    k=0;
    for (i=1;i<5;i++)
        for (j=1;j<5;j++)
            if (num[i][j]!=0) k++;
    if (k==16) {return;}        
    i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    while (num[i][j]!=0){
        i=1+(int)(4.0*rand()/(RAND_MAX+1.0));
        j=1+(int)(4.0*rand()/(RAND_MAX+1.0));
    } 
    num[i][j]=2;
    outt();
}
QQ截图20150106164008.png




评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
拈花小仙 + 5 + 5 + 3 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2015-1-6 16:57:41 | 显示全部楼层
必须顶,不解释~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 14:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表