J2ME连连看基础功能源代码(含详细注释) - 编程入门网
作者 佚名技术
来源 NET编程
浏览
发布时间 2012-06-19
} //先移动列,再移动行 if(isEmptyCell(r2,c1)){//转折点为空 if(isEmptyCol(r1,c1,r2,c1) & isEmptyRow(r2,c1,r2,c2)) { return ONE_CORNER_FIRSTY; } } //无连接 return NO_LINK; } /** * 是否经过2次转折实现连接 * @param r1 块1的行号 * @param c1 块1的列号 * @param r2 块2的行号 * @param c2 块2的列号 * @return true代表可以连接,false代表不能 */ private boolean isTwoCornerLink(int r1,int c1,int r2,int c2){ int result; //正常情况,划分成4个方向 //块1向上 for(int row = r1 -1;row >= 0;row--){ //如果有数据不为空,则直接结束该方向的尝试 if(map[row][c1] != 0){ break; } //存储第一个拐点的坐标 p[0] = row; p[1] = c1; //每次都尝试转折,则变成一个转点的操作 result = isOneCornerLink(row,c1,r2,c2); //如果可以连接 if(result != NO_LINK){ //存储第二个拐点的位置 switch(result){ case ONE_CORNER_FIRSTX: p[2] = row; p[3] = c2; break; case ONE_CORNER_FIRSTY: p[2] = r2; p[3] = c1; break; } return true; } } //块1向下 for(int row = r1 + 1;row < MAX_ROW;row++){ //如果有数据不为空,则直接结束该方向的尝试 if(map[row][c1] != 0){ break; } //存储第一个拐点的坐标 p[0] = row; p[1] = c1; //每次都尝试转折,则变成一个转点的操作 result = isOneCornerLink(row,c1,r2,c2); //如果可以连接 if(result != NO_LINK){ //存储第二个拐点的位置 switch(result){ case ONE_CORNER_FIRSTX: p[2] = row; p[3] = c2; break; case ONE_CORNER_FIRSTY: p[2] = r2; p[3] = c1; break; } return true; } } //块1向左 for(int col = c1 -1;col >= 0;col--){ //如果有数据不为空,则直接结束该方向的尝试 if(map[r1][col] != 0){ break; } //存储第一个拐点的坐标 p[0] = r1; p[1] = col; //每次都尝试转折,则变成一个转点的操作 result = isOneCornerLink(r1,col,r2,c2); //如果可以连接 if(result != NO_LINK){ //存储第二个拐点的位置 switch(result){ case ONE_CORNER_FIRSTX: p[2] = r1; p[3] = c2; break; |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于J2ME连连看基础功能源代码(含详细注释) - 编程入门网的所有评论