码迷,mamicode.com
首页 > 其他好文 > 详细

2048等待写java版本

时间:2016-06-07 06:43:20      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:小代码 2048 c语言版本

 <html>
<HEAD></HEAD>
<BODY>
 <a href="0.html">-0-</a> 
<a href="1.html">-1-</a> 
<a href="2.html">-2-</a> 
<a href="3.html">-3-</a> 
<a href="4.html">-4-</a> 
<a href="5.html">-5-</a> 
<a href="6.html">-6-</a> 
<a href="7.html">-7-</a>
 <a href="8.html">-8-</a>
 <a href="9.html">-9-</a>
<textarea rows="50" cols="50"> 

 /***************
2048 目前带向上h和向左的bug
随机数
程序运行时判断相同数
刷屏
程序运行环境 vs2012或linux
**************/
#include<time.h>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
using namespace std;
int a[5][5]={0};
void show()
{
for(int i=0;i<5;i++)
{
for(int j=0;j<5;j++)
cout<<a[i][j]<<" ";
cout<<endl;
}
}
void fun(int state)
{
int i=0,j=0,k;
for(  i=0;i<5;i++)
{
  for(  j=0;j<4;j++)
    {
  if (a[i][j]==a[i][j+1])
      {
         a[i][j]=2*a[i][j];
         a[i][j+1]=0;
      }
       
    } 

}
if(state==1)
 {
for(i=0;i<5;i++)
{
  for(  j=4;j>0;j--)
    {
  if (a[i][j]!=0)continue;
  else {k=j-1;
           while(a[i][k]==0){ k--;           }
           if(k>=0){ a[i][j]=a[i][k];a[i][k]=0;}
      }
       
    } 
  }
}

}
void fundown(int state)
{
int i=0,j=0,k;
for(  j=0;j<5;j++)
{
  for(  i=0;i<4;i++)
    {
    if (a[i][j]==a[i+1][j])
      {
         a[i][j]=2*a[i][j];
         a[i+1][j]=0;
      }
       
    } 

}
if(state==1)
 {
  for(j=0;j<5;j++)
    {
       for(i=4;i>0;i--)
        {

         if (a[i][j]!=0)continue;
          else {k=i-1;
           while(a[k][j]==0){ k--; }
           if(k>=0){ a[i][j]=a[k][j];a[k][j]=0;}
          }

       }             
    } 
  }


}

int check()
{int s=0,i,j;
  for(i=0;i<5;i++)
    {
     for(j=0;j<5;j++)
       {
        if(a[i][j]==2048){cout<<"good"<<endl;}
        if(a[i][j]==4096){cout<<"good"<<endl;}
        if(a[i][j]==0){s=1;}
       }
    }
if(!s){cout<<" no empty";exit(0);}
return s;
}
void randnum()
{
srand(time(0));
int r=rand()%5;
if(a[0][r]==0)a[0][r]=2;
else if (a[4][r]!=0) a[4][r]=2;
  else {
 for(int i=0;i<5;i++) 
  for(int j=0;j<5;j++) 
    a[i][j]=2;
}

}
void play()
{
char ss=‘c‘;
cout<<" enter sxzc"<<endl;
cin>>ss;
switch(ss)
{
case ‘s‘:fundown(2);break;
case ‘x‘:fundown(1);break;
case ‘z‘:fun(2);break;
case ‘c‘:fun(1);break;
}
}
int main()
{ int st=1;
  while(st)
   {
   randnum();
   show();
   play();
    st=check();
      system("clear");
 }
 return 0;
}
int main1()
{ 
show();
int state=1;
fundown(state);
show();
return 0;

}
</textarea>
<textarea rows="50" cols="50">
bug 
在于上与左 方向的产生
移动数据实现第一步
即 20200 向右移动会是 02020的结果??
所以还更应该优化这个代码
 </textarea>
<textarea rows="50" cols="50"> 
gcc -o main main.c fun.h fun.c
ls -lh
d+G(shift+g)
10dd
10yy
:/int a

</textarea>
<textarea rows="50" cols="50"> 
http://blog.csdn.net/fred1653/article/details/9322583/
http://www.2cto.com/os/201508/431266.html

http://wenku.baidu.com/view/4fbb197527284b73f242509f.html
文件结束标志 eof 还有ueof是完全不同的
</textarea>
<textarea rows="50" cols="50"> 
/**
基数排序
偏移量版本
桶容量版本
**/
 #include <stdio.h>
#include <stdlib.h>
#include <iostream>
using namespace std;
int  a[]={1,3,5,7,9,2,4,6,8,11,13,15,17,22,24,26,28};
int len=sizeof(a)/sizeof(a[0]);
void show()
{int i=0;
while(i<len)cout<<a[i]<<" ";cout<<endl;
}
void sort(int a[])
{
int b[3][10]={0};
//MAX
int  max=10;
int i=0,j=1;
for(i=0;i<len;i++)
{ while(a[i]>max)
  {
  max=max*10;
  j++;
 }
}
// 按位模除处理
  max=10;
for(i=0;i<j;i++)
{
int n=len-1;int kk=0;
 while(n--)
{
int xx=a[n]%max;
//放入
while(b[kk][xx]!=0 )
{
kk++;
}
b[kk][xx]=a[n];
kk=0;
}
//转回原来的位置

//循环结束自然数组a就排好了
max=max*10;
}
}
</textarea>
<textarea rows="50" cols="50"> </textarea>
<textarea rows="50" cols="50"> </textarea>
<textarea rows="50" cols="50"> </textarea>
<textarea rows="50" cols="50"> </textarea>
<textarea rows="50" cols="50"> </textarea>
</BODY>
</html>


2048等待写java版本

标签:小代码 2048 c语言版本

原文地址:http://wzsts.blog.51cto.com/10251779/1786748

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!