• 回答数

    5

  • 浏览数

    203

寳呗颖1
首页 > 期刊论文 > java连连看毕业论文

5个回答 默认排序
  • 默认排序
  • 按时间排序

LD中国王海如

已采纳

楼主觉悟吧。。。

300 评论

珠宝理财

刚试了。。测试通过。。.*;.*;.*; publicclass LianLianKan implements ActionListener { JFrame mainFrame; // 主面板 Container thisContainer; JPanel centerPanel, southPanel, northPanel; //子面板 JButton diamondsButton[][] = newJButton[6][5];// 游戏按钮数组 JButton exitButton, resetButton, newlyButton;// 退出,重列,重新开始按钮 JLabel fractionLable = newJLabel("0"); // 分数标签 JButton firstButton, secondButton; // 分别记录两次被选中的按钮 // 储存游戏按钮位置(这里其实只要6行,5列。但是我们用了8行,7列。是等于在这个面板按钮的周围还围 //了一层是0的按钮,这样就可以实现靠近面板边缘的两个按钮可以消去) int grid[][] = new int[8][7]; static boolean pressInformation = false; // 判断是否有按钮被选中 int x0 = 0, y0 = 0, x = 0, y = 0, fristMsg =0, secondMsg = 0, validateLV; // 游戏按钮的位置坐标 int i, j, k, n;// 消除方法控制 public void init() { mainFrame = new JFrame("JKJ连连看"); thisContainer = (); (new BorderLayout()); centerPanel = new JPanel(); southPanel = new JPanel(); northPanel = new JPanel(); (centerPanel,"Center"); (southPanel,"South"); (northPanel,"North"); (new GridLayout(6, 5)); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { diamondsButton[cols][rows] = newJButton(String .valueOf(grid[cols + 1][rows + 1])); diamondsButton[cols][rows].addActionListener(this); (diamondsButton[cols][rows]); } } exitButton = new JButton("退出"); (this); resetButton = new JButton("重列"); (this); newlyButton = new JButton("再来一局"); (this); (exitButton); (resetButton); (newlyButton); (((fractionLable .getText()))); (fractionLable); (280, 100, 500, 450); (true); (); } public void randomBuild() { int randoms, cols, rows; for (int twins = 1; twins <= 15; twins++){//一共15对button,30个 randoms = (int) (() * 25 +1);//button上的数字 for (int alike = 1; alike <= 2; alike++){ cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) {//等于0说明这个空格有了button cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = randoms; } } } public void fraction() { (((fractionLable .getText()) + 100)); } public void reload() { int save[] = new int[30]; int n = 0, cols, rows; int grid[][] = new int[8][7]; for (int i = 0; i <= 6; i++) { for (int j = 0; j <= 5; j++) { if ([i][j] != 0) { save[n] = [i][j];//记下每个button的数字 n++;//有几个没有消去的button } } } n = n - 1; = grid; while (n >= 0) {//把没有消去的button重新放一次 cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) { cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = save[n]; n--; } (false); pressInformation = false; // 这里一定要将按钮点击信息归为初始 init(); for (int i = 0; i < 6; i++) { for (int j = 0; j < 5; j++) { if (grid[i + 1][j + 1] == 0) diamondsButton[i][j].setVisible(false); } } } public void estimateEven(int placeX, intplaceY, JButton bz) { if (pressInformation == false) { x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; pressInformation = true; } else { x0 = x; y0 = y; fristMsg = secondMsg; firstButton = secondButton; x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; if (fristMsg == secondMsg &&secondButton != firstButton) { xiao(); } } } public void xiao() { // 相同的情况下能不能消去。仔细分析,不一条条注释 if ((x0 == x && (y0 == y + 1 || y0 ==y - 1)) || ((x0 == x + 1 || x0 == x - 1) &&(y0 == y))) { // 判断是否相邻 remove(); } else { for (j = 0; j < 7; j++) { if (grid[x0][j] == 0) { // 判断和第一个按钮同行的哪个按钮为空 //如果找到一个为空的,就按列值的三种情况比较第二个按钮与空按钮的位置 if (y > j) {//第二个按钮在空按钮右边 for (i = y - 1; i >= j; i--) { //检测从第二个按钮横向左边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break;//存在非空格的就退出,这一退出就不可能k==2了,所以就会到下而215行出同理的判断列 } else { k = 1; } // K=1说明全是空格通过了第一次验证,也就是从第二个按钮横向左边到空格所在列为止全是空格 } if (k == 1) { linePassOne();//进入第二次验证,也就是从第一个按钮到它同行的空格之间的空格判断 } } if (y < j) { // 第二个按钮在空按钮左边 for (i = y + 1; i <= j; i++) {//检测从第二个按钮横向右边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { linePassOne(); } } if (y == j) {//第二个按钮和空按钮同列 linePassOne(); } } //第三次检测,检测确定为空的第j列的那个按钮竖向到第二个按钮,看是不是有按钮 if (k == 2) { if (x0 == x) {//第一,二按钮在同行 remove(); } if (x0 < x) {//第一按钮在第二按钮下边 for (n = x0; n <= x - 1; n++) {//从空按钮竖向到第二个按钮所在行是否有按钮 if (grid[n][j] != 0) { k= 0; break; } //没有按钮,说明这条路经就通了 if (grid[n][j] == 0 && n == x -1) { remove(); } } } if (x0 > x) {//第一按钮在第二按钮上边 for (n = x0; n >= x + 1; n--) { if (grid[n][j] != 0) { k = 0; break; } if (grid[n][j] == 0 && n == x +1) { remove(); } } } } }//-------------------------------------for //当上面的检测与第一个按钮同行的空格按钮失败后(不能找到与第二个按钮的相连路经),下面就执行 //检测与第一个按钮同列的空格按钮 for (i = 0; i < 8; i++) { if (grid[i][y0] == 0) {// 判断和第一个按钮同列的哪个按钮为空 if (x > i) {//第二个按钮在这个空按钮的下面 for (j = x - 1; j >= i; j--) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x < i) {//第二个按钮在这个空按钮的上面 for (j = x + 1; j <= i; j++) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x == i) {//第二个按钮与这个空按钮同行 rowPassOne(); } } if (k == 2) { if (y0 == y) {//第二个按钮与第一个按钮同列 remove(); } if (y0 < y) {//第二个按钮在第一个按钮右边 for (n = y0; n <= y - 1; n++) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y -1) { remove(); } } } if (y0 > y) {//第二个按钮在第一个按钮左边 for (n = y0; n >= y + 1; n--) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y +1) { remove(); } } } } }//--------------------------------for }//-------------else }//------------xiao public void linePassOne() { if (y0 > j) { // 第一按钮同行空按钮在左边 for (i = y0 - 1; i >= j; i--) { // 判断第一按钮同左侧空按钮之间有没按钮 if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } // K=2说明通过了第二次验证 } } if (y0 < j) { // 第一按钮同行空按钮在右边 for (i = y0 + 1; i <= j; i++) { if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } } } } public void rowPassOne() { if (x0 > i) {//第一个按钮在与它同列的那个空格按钮下面 for (j = x0 - 1; j >= i; j--) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } if (x0 < i) {//第一个按钮在与它同列的那个空格按钮上面 for (j = x0 + 1; j <= i; j++) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } } public void remove() { (false); (false); fraction(); pressInformation = false; k = 0; grid[x0][y0] = 0; grid[x][y] = 0; } public void actionPerformed(ActionEvent e) { if (() == newlyButton) { int grid[][] = new int[8][7]; = grid; randomBuild(); (false); pressInformation = false; init(); } if (() == exitButton) (0); if (() == resetButton) reload(); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { if (() ==diamondsButton[cols][rows]) estimateEven(cols + 1, rows + 1,diamondsButton[cols][rows]); } } } public static void main(String[] args) { LianLianKan llk = new LianLianKan(); (); (); }}

278 评论

多儿的妈咪

我以前自己写一个玩的。没有把你要求的功能全部实现,不过你看了后可以改一下就好了。参考一下吧,我给了注解:package ;/* * lianliankan总体算法思路:由两个确定的按钮。若这两个按钮的数字相等,就开始找它们相连的路经。这个找路经 * 分3种情况:(从下面的这三种情况,我们可以知道,需要三个检测,这三个检测分别检测一条直路经。这样就会有 * 三条路经。若这三条路经上都是空按钮,那么就刚好是三种直线(两个转弯点)把两个按钮连接起来了) * 1.相邻 * * 2. 若不相邻的先在第一个按钮的同行找一个空按钮。1).找到后看第二个按钮横向到这个空按钮 * 所在的列是否有按钮。2).没有的话再看第一个按钮到与它同行的那个空按钮之间是否有按钮。3).没有的话,再从 * 与第一个按钮同行的那个空按钮竖向到与第二个按钮的同行看是否有按钮。没有的话路经就通了,可以消了. * * 3.若2失败后,再在第一个按钮的同列找一个空按钮。1).找到后看第二个按钮竖向到这个空按钮所在的行是否有按钮。 * 2).没有的话,再看第一个按钮到与它同列的那个空按钮之间是否有按钮。3).没有的话,再从与第一个按钮同列的 * 那个空按钮横向到与第二个按钮同列看是否有按钮。没有的话路经就通了,可以消了。 * * 若以上三步都失败,说明这两个按钮不可以消去。 */import .*;import .*;import .*;public class LianLianKan implements ActionListener { JFrame mainFrame; // 主面板 Container thisContainer; JPanel centerPanel, southPanel, northPanel; // 子面板 JButton diamondsButton[][] = new JButton[6][5];// 游戏按钮数组 JButton exitButton, resetButton, newlyButton; // 退出,重列,重新开始按钮 JLabel fractionLable = new JLabel("0"); // 分数标签 JButton firstButton, secondButton; // 分别记录两次被选中的按钮 // 储存游戏按钮位置(这里其实只要6行,5列。但是我们用了8行,7列。是等于在这个面板按钮的周围还围 //了一层是0的按钮,这样就可以实现靠近面板边缘的两个按钮可以消去) int grid[][] = new int[8][7]; static boolean pressInformation = false; // 判断是否有按钮被选中 int x0 = 0, y0 = 0, x = 0, y = 0, fristMsg = 0, secondMsg = 0, validateLV; // 游戏按钮的位置坐标 int i, j, k, n;// 消除方法控制 public void init() { mainFrame = new JFrame("JKJ连连看"); thisContainer = (); (new BorderLayout()); centerPanel = new JPanel(); southPanel = new JPanel(); northPanel = new JPanel(); (centerPanel, "Center"); (southPanel, "South"); (northPanel, "North"); (new GridLayout(6, 5)); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { diamondsButton[cols][rows] = new JButton(String .valueOf(grid[cols + 1][rows + 1])); diamondsButton[cols][rows].addActionListener(this); (diamondsButton[cols][rows]); } } exitButton = new JButton("退出"); (this); resetButton = new JButton("重列"); (this); newlyButton = new JButton("再来一局"); (this); (exitButton); (resetButton); (newlyButton); (((fractionLable .getText()))); (fractionLable); (280, 100, 500, 450); (true); (); } public void randomBuild() { int randoms, cols, rows; for (int twins = 1; twins <= 15; twins++) {//一共15对button,30个 randoms = (int) (() * 25 + 1);//button上的数字 for (int alike = 1; alike <= 2; alike++) { cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) {//等于0说明这个空格有了button cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = randoms; } } } public void fraction() { (((fractionLable .getText()) + 100)); } public void reload() { int save[] = new int[30]; int n = 0, cols, rows; int grid[][] = new int[8][7]; for (int i = 0; i <= 6; i++) { for (int j = 0; j <= 5; j++) { if ([i][j] != 0) { save[n] = [i][j];//记下每个button的数字 n++;//有几个没有消去的button } } } n = n - 1; = grid; while (n >= 0) {//把没有消去的button重新放一次 cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) { cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = save[n]; n--; } (false); pressInformation = false; // 这里一定要将按钮点击信息归为初始 init(); for (int i = 0; i < 6; i++) { for (int j = 0; j < 5; j++) { if (grid[i + 1][j + 1] == 0) diamondsButton[i][j].setVisible(false); } } } public void estimateEven(int placeX, int placeY, JButton bz) { if (pressInformation == false) { x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; pressInformation = true; } else { x0 = x; y0 = y; fristMsg = secondMsg; firstButton = secondButton; x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; if (fristMsg == secondMsg && secondButton != firstButton) { xiao(); } } } public void xiao() { // 相同的情况下能不能消去。仔细分析,不一条条注释 if ((x0 == x && (y0 == y + 1 || y0 == y - 1)) || ((x0 == x + 1 || x0 == x - 1) && (y0 == y))) { // 判断是否相邻 remove(); } else { for (j = 0; j < 7; j++) { if (grid[x0][j] == 0) { // 判断和第一个按钮同行的哪个按钮为空 //如果找到一个为空的,就按列值的三种情况比较第二个按钮与空按钮的位置 if (y > j) {//第二个按钮在空按钮右边 for (i = y - 1; i >= j; i--) { //检测从第二个按钮横向左边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break;//存在非空格的就退出,这一退出就不可能k==2了,所以就会到下而215行出同理的判断列 } else { k = 1; } // K=1说明全是空格通过了第一次验证,也就是从第二个按钮横向左边到空格所在列为止全是空格 } if (k == 1) { linePassOne();//进入第二次验证,也就是从第一个按钮到它同行的空格之间的空格判断 } } if (y < j) { // 第二个按钮在空按钮左边 for (i = y + 1; i <= j; i++) {//检测从第二个按钮横向右边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { linePassOne(); } } if (y == j) {//第二个按钮和空按钮同列 linePassOne(); } } //第三次检测,检测确定为空的第j列的那个按钮竖向到第二个按钮,看是不是有按钮 if (k == 2) { if (x0 == x) {//第一,二按钮在同行 remove(); } if (x0 < x) {//第一按钮在第二按钮下边 for (n = x0; n <= x - 1; n++) {//从空按钮竖向到第二个按钮所在行是否有按钮 if (grid[n][j] != 0) { k = 0; break; } //没有按钮,说明这条路经就通了 if (grid[n][j] == 0 && n == x - 1) { remove(); } } } if (x0 > x) {//第一按钮在第二按钮上边 for (n = x0; n >= x + 1; n--) { if (grid[n][j] != 0) { k = 0; break; } if (grid[n][j] == 0 && n == x + 1) { remove(); } } } } }//-------------------------------------for //当上面的检测与第一个按钮同行的空格按钮失败后(不能找到与第二个按钮的相连路经),下面就执行 //检测与第一个按钮同列的空格按钮 for (i = 0; i < 8; i++) { if (grid[i][y0] == 0) {// 判断和第一个按钮同列的哪个按钮为空 if (x > i) {//第二个按钮在这个空按钮的下面 for (j = x - 1; j >= i; j--) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x < i) {//第二个按钮在这个空按钮的上面 for (j = x + 1; j <= i; j++) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x == i) {//第二个按钮与这个空按钮同行 rowPassOne(); } } if (k == 2) { if (y0 == y) {//第二个按钮与第一个按钮同列 remove(); } if (y0 < y) {//第二个按钮在第一个按钮右边 for (n = y0; n <= y - 1; n++) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y - 1) { remove(); } } } if (y0 > y) {//第二个按钮在第一个按钮左边 for (n = y0; n >= y + 1; n--) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y + 1) { remove(); } } } } }//--------------------------------for }//-------------else }//------------xiao public void linePassOne() { if (y0 > j) { // 第一按钮同行空按钮在左边 for (i = y0 - 1; i >= j; i--) { // 判断第一按钮同左侧空按钮之间有没按钮 if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } // K=2说明通过了第二次验证 } } if (y0 < j) { // 第一按钮同行空按钮在右边 for (i = y0 + 1; i <= j; i++) { if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } } } } public void rowPassOne() { if (x0 > i) {//第一个按钮在与它同列的那个空格按钮下面 for (j = x0 - 1; j >= i; j--) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } if (x0 < i) {//第一个按钮在与它同列的那个空格按钮上面 for (j = x0 + 1; j <= i; j++) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } } public void remove() { (false); (false); fraction(); pressInformation = false; k = 0; grid[x0][y0] = 0; grid[x][y] = 0; } public void actionPerformed(ActionEvent e) { if (() == newlyButton) { int grid[][] = new int[8][7]; = grid; randomBuild(); (false); pressInformation = false; init(); } if (() == exitButton) (0); if (() == resetButton) reload(); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { if (() == diamondsButton[cols][rows]) estimateEven(cols + 1, rows + 1, diamondsButton[cols][rows]); } } } public static void main(String[] args) { LianLianKan llk = new LianLianKan(); (); (); }}

157 评论

冒火得很000

我帮你分析了一下,把程序的思路帮你了出来,难理解的地方也写了出来,看看吧:/* * lianliankan总体算法思路:由两个确定的按钮。若这两个按钮的数字相等,就开始找它们相连的路经。这个找路经 * 分3种情况:(从下面的这三种情况,我们可以知道,需要三个检测,这三个检测分别检测一条直路经。这样就会有 * 三条路经。若这三条路经上都是空按钮,那么就刚好是三种直线(两个转弯点)把两个按钮连接起来了) * 1.相邻 * * 2. 若不相邻的先在第一个按钮的同行找一个空按钮。1).找到后看第二个按钮横向到这个空按钮 * 所在的列是否有按钮。2).没有的话再看第一个按钮到与它同行的那个空按钮之间是否有按钮。3).没有的话,再从 * 与第一个按钮同行的那个空按钮竖向到与第二个按钮的同行看是否有按钮。没有的话路经就通了,可以消了. * * 3.若2失败后,再在第一个按钮的同列找一个空按钮。1).找到后看第二个按钮竖向到这个空按钮所在的行是否有按钮。 * 2).没有的话,再看第一个按钮到与它同列的那个空按钮之间是否有按钮。3).没有的话,再从与第一个按钮同列的 * 那个空按钮横向到与第二个按钮同列看是否有按钮。没有的话路经就通了,可以消了。 * * 若以上三步都失败,说明这两个按钮不可以消去。 */import .*;import .*;import .*;public class LianLianKan implements ActionListener { JFrame mainFrame; // 主面板 Container thisContainer; JPanel centerPanel, southPanel, northPanel; // 子面板 JButton diamondsButton[][] = new JButton[6][5];// 游戏按钮数组 JButton exitButton, resetButton, newlyButton; // 退出,重列,重新开始按钮 JLabel fractionLable = new JLabel("0"); // 分数标签 JButton firstButton, secondButton; // 分别记录两次被选中的按钮 // 储存游戏按钮位置(这里其实只要6行,5列。但是我们用了8行,7列。是等于在这个面板按钮的周围还围 //了一层是0的按钮,这样就可以实现靠近面板边缘的两个按钮可以消去) int grid[][] = new int[8][7]; static boolean pressInformation = false; // 判断是否有按钮被选中 int x0 = 0, y0 = 0, x = 0, y = 0, fristMsg = 0, secondMsg = 0, validateLV; // 游戏按钮的位置坐标 int i, j, k, n;// 消除方法控制 public void init() { mainFrame = new JFrame("JKJ连连看"); thisContainer = (); (new BorderLayout()); centerPanel = new JPanel(); southPanel = new JPanel(); northPanel = new JPanel(); (centerPanel, "Center"); (southPanel, "South"); (northPanel, "North"); (new GridLayout(6, 5)); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { diamondsButton[cols][rows] = new JButton(String .valueOf(grid[cols + 1][rows + 1])); diamondsButton[cols][rows].addActionListener(this); (diamondsButton[cols][rows]); } } exitButton = new JButton("退出"); (this); resetButton = new JButton("重列"); (this); newlyButton = new JButton("再来一局"); (this); (exitButton); (resetButton); (newlyButton); (((fractionLable .getText()))); (fractionLable); (280, 100, 500, 450); (true); (); } public void randomBuild() { int randoms, cols, rows; for (int twins = 1; twins <= 15; twins++) {//一共15对button,30个 randoms = (int) (() * 25 + 1);//button上的数字 for (int alike = 1; alike <= 2; alike++) { cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) {//等于0说明这个空格有了button cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = randoms; } } } public void fraction() { (((fractionLable .getText()) + 100)); } public void reload() { int save[] = new int[30]; int n = 0, cols, rows; int grid[][] = new int[8][7]; for (int i = 0; i <= 6; i++) { for (int j = 0; j <= 5; j++) { if ([i][j] != 0) { save[n] = [i][j];//记下每个button的数字 n++;//有几个没有消去的button } } } n = n - 1; = grid; while (n >= 0) {//把没有消去的button重新放一次 cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); while (grid[cols][rows] != 0) { cols = (int) (() * 6 + 1); rows = (int) (() * 5 + 1); } [cols][rows] = save[n]; n--; } (false); pressInformation = false; // 这里一定要将按钮点击信息归为初始 init(); for (int i = 0; i < 6; i++) { for (int j = 0; j < 5; j++) { if (grid[i + 1][j + 1] == 0) diamondsButton[i][j].setVisible(false); } } } public void estimateEven(int placeX, int placeY, JButton bz) { if (pressInformation == false) { x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; pressInformation = true; } else { x0 = x; y0 = y; fristMsg = secondMsg; firstButton = secondButton; x = placeX; y = placeY; secondMsg = grid[x][y]; secondButton = bz; if (fristMsg == secondMsg && secondButton != firstButton) { xiao(); } } } public void xiao() { // 相同的情况下能不能消去。仔细分析,不一条条注释 if ((x0 == x && (y0 == y + 1 || y0 == y - 1)) || ((x0 == x + 1 || x0 == x - 1) && (y0 == y))) { // 判断是否相邻 remove(); } else { for (j = 0; j < 7; j++) { if (grid[x0][j] == 0) { // 判断和第一个按钮同行的哪个按钮为空 //如果找到一个为空的,就按列值的三种情况比较第二个按钮与空按钮的位置 if (y > j) {//第二个按钮在空按钮右边 for (i = y - 1; i >= j; i--) { //检测从第二个按钮横向左边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break;//存在非空格的就退出,这一退出就不可能k==2了,所以就会到下而215行出同理的判断列 } else { k = 1; } // K=1说明全是空格通过了第一次验证,也就是从第二个按钮横向左边到空格所在列为止全是空格 } if (k == 1) { linePassOne();//进入第二次验证,也就是从第一个按钮到它同行的空格之间的空格判断 } } if (y < j) { // 第二个按钮在空按钮左边 for (i = y + 1; i <= j; i++) {//检测从第二个按钮横向右边到空格所在列为止是否全是空格 if (grid[x][i] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { linePassOne(); } } if (y == j) {//第二个按钮和空按钮同列 linePassOne(); } } //第三次检测,检测确定为空的第j列的那个按钮竖向到第二个按钮,看是不是有按钮 if (k == 2) { if (x0 == x) {//第一,二按钮在同行 remove(); } if (x0 < x) {//第一按钮在第二按钮下边 for (n = x0; n <= x - 1; n++) {//从空按钮竖向到第二个按钮所在行是否有按钮 if (grid[n][j] != 0) { k = 0; break; } //没有按钮,说明这条路经就通了 if (grid[n][j] == 0 && n == x - 1) { remove(); } } } if (x0 > x) {//第一按钮在第二按钮上边 for (n = x0; n >= x + 1; n--) { if (grid[n][j] != 0) { k = 0; break; } if (grid[n][j] == 0 && n == x + 1) { remove(); } } } } }//-------------------------------------for //当上面的检测与第一个按钮同行的空格按钮失败后(不能找到与第二个按钮的相连路经),下面就执行 //检测与第一个按钮同列的空格按钮 for (i = 0; i < 8; i++) { if (grid[i][y0] == 0) {// 判断和第一个按钮同列的哪个按钮为空 if (x > i) {//第二个按钮在这个空按钮的下面 for (j = x - 1; j >= i; j--) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x < i) {//第二个按钮在这个空按钮的上面 for (j = x + 1; j <= i; j++) { if (grid[j][y] != 0) { k = 0; break; } else { k = 1; } } if (k == 1) { rowPassOne(); } } if (x == i) {//第二个按钮与这个空按钮同行 rowPassOne(); } } if (k == 2) { if (y0 == y) {//第二个按钮与第一个按钮同列 remove(); } if (y0 < y) {//第二个按钮在第一个按钮右边 for (n = y0; n <= y - 1; n++) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y - 1) { remove(); } } } if (y0 > y) {//第二个按钮在第一个按钮左边 for (n = y0; n >= y + 1; n--) { if (grid[i][n] != 0) { k = 0; break; } if (grid[i][n] == 0 && n == y + 1) { remove(); } } } } }//--------------------------------for }//-------------else }//------------xiao public void linePassOne() { if (y0 > j) { // 第一按钮同行空按钮在左边 for (i = y0 - 1; i >= j; i--) { // 判断第一按钮同左侧空按钮之间有没按钮 if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } // K=2说明通过了第二次验证 } } if (y0 < j) { // 第一按钮同行空按钮在右边 for (i = y0 + 1; i <= j; i++) { if (grid[x0][i] != 0) { k = 0; break; } else { k = 2; } } } } public void rowPassOne() { if (x0 > i) {//第一个按钮在与它同列的那个空格按钮下面 for (j = x0 - 1; j >= i; j--) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } if (x0 < i) {//第一个按钮在与它同列的那个空格按钮上面 for (j = x0 + 1; j <= i; j++) { if (grid[j][y0] != 0) { k = 0; break; } else { k = 2; } } } } public void remove() { (false); (false); fraction(); pressInformation = false; k = 0; grid[x0][y0] = 0; grid[x][y] = 0; } public void actionPerformed(ActionEvent e) { if (() == newlyButton) { int grid[][] = new int[8][7]; = grid; randomBuild(); (false); pressInformation = false; init(); } if (() == exitButton) (0); if (() == resetButton) reload(); for (int cols = 0; cols < 6; cols++) { for (int rows = 0; rows < 5; rows++) { if (() == diamondsButton[cols][rows]) estimateEven(cols + 1, rows + 1, diamondsButton[cols][rows]); } } } public static void main(String[] args) { LianLianKan llk = new LianLianKan(); (); (); }}

248 评论

心晴joanny

你认为做100个按钮可行么?100个按钮,100个对象!直接画出来然后监听区域就行了。。。

337 评论

相关问答

  • java连连看毕业论文

    楼主觉悟吧。。。

    寳呗颖1 5人参与回答 2023-12-09
  • 连连看游戏毕业论文

    活动目标:1.有参与操作活动的兴趣,体验在探索中创作的快乐;2.大胆尝试几种常见的连接方法,发现物体间的连接有的需要辅助物,有的不需要辅助物;3.能积极参与各种

    偶素小cici 7人参与回答 2023-12-10
  • 超好看杂志还在连载么

    是萧鼎本人写的微博上说过了现在网上更新到12章,(其实很少)还在《超好看》杂志上连载要看的话可以去诛仙贴吧也可以去磨铁中文网,但磨铁没有开放要有内部邮箱才行哦。

    Yuan圆圆圆 4人参与回答 2023-12-10
  • 毕业论文连锁行业

    餐饮连锁经营是现代餐饮企业发展壮大的一种必然趋势,我精心推荐的一些餐饮连锁经营管理论文,希望你能有所感触!餐饮连锁经营管理论文篇一 餐饮业的连锁经营

    AlpacaZhou 2人参与回答 2023-12-07
  • 连连看网页游戏毕业论文

    在我们平凡的日常里,大家都不可避免地要接触到作文吧,作文根据体裁的不同可以分为记叙文、说明文、应用文、议论文。如何写一篇有思想、有文采的作文呢?以下是我精心整理

    纽约纽约k 3人参与回答 2023-12-07