Dominosa/数邻(2) | C++ | BFS

news2025/1/21 9:00:07

目录

    • 一、Dominosa简介
    • 二、题目描述
    • 三、编程思路
    • 四、完整代码

一、Dominosa简介

   Dominosa,中文名称为数邻,是一种棋盘游戏,基于骨牌的排列和匹配来进行。它是从骨牌游戏中发展而来的,在骨牌的基础上添加了一些规则和难度。具体的游戏规则是:将一副骨牌放置在一个棋盘上,玩家需要根据这些固定数字推断出正确的骨牌排列。

   Dominosa 是一款非常有趣和具有挑战性的游戏。我是在大三小学期的 Linux 实训中,在虚拟机上接触到了这个小游戏。由于我本身玩过骨牌,同时对这种类型的数学游戏也很感兴趣,它们实在是令我着迷。

   Dominosa 需要玩家运用逻辑思维和推理能力来解决问题。它的规则相对简单,但难度却很高,因为骨牌排列的可能性非常多。如果您喜欢逻辑游戏,并且想尝试一些挑战性的新游戏,那么 Dominosa 绝对值得一试!

   对于没有接触过骨牌的同学来说或许还不太能理解这个游戏,那么我们下面举一个具体的例子。下面是一个经典的 Dominosa 谜面。

在这里插入图片描述

答案如下:

在这里插入图片描述

   可见,盘面上的数字被两两划分,且保证每个划分都互不重复。

   我相信看完例子你一定懂了这个游戏的规则!现在,请你编写一个程序,对于给定的 Dominosa 谜面,能够自动判断是否有解,如果有解,还能够给出一个正确的解。

二、题目描述

输入一个未解的 Dominosa 谜面,输出它的结果。
Input
由两部分输入组成。第一部分只有一个正整数n,表示最大数字,第二部分有n+1行,每行n+2个正整数,表示谜面。
Output
谜题的解,如果两个数字能够组成一个骨牌,那么将它们的位置标记为相同的数字。标记方法可能不唯一,但是标记必须容易辨认。

测试用例1
在这里插入图片描述

测试用例2
在这里插入图片描述
输入(供复制):
9
82419008183
64907897150
03198511218
68804535022
37763052729
74416693226
36165567745
81442980856
42513904405
93269977337

三、编程思路

在昨天的代码基础上,

  1. 将求解的步骤单独写成一个函数
  2. 当需要用到BFS的时候,可以递归调用这个求解函数
  3. 当找到正确解后,输出正确解,然后逐层返回,程序结束

四、完整代码

说明:代码中默认为输出到命令行中,我们也提供了输出到文件中的选项,只要在程序的第 390-395 行,更改被注释的内容即可。

#include<bits/stdc++.h>
using namespace std;
int N = 30;							// N: 最大数字,不难计算出盘面的行数=N+1,列数=N+2
// 定义单格
typedef struct {
	int number = -1;						// 表示当前格内的数字,初始是-1
	int con = 0;							// 表示当前格是否已建立连接,如果未连接,则为0,如果已连接,则为1
	int up=1, down=1, left=1, right=1;		// 标记当前格的上、下、左、右格子是否可能建立连接,如果可能则为1,如果不能则为0
	int sequ = 0;
} Single;

// 定义骨牌
typedef struct {
	int count;				// 编号:以6为例,00->0, 01->1, ..., 06->6, 11->7, ..., 16->12, 22->13, ..., 55->25, 56->26, 66->27;count是每种骨牌的数量
	bool used;				// used是骨牌是否已经出现过,若已经出现过则为true
} bridge;

int addd(int m){			// 一个求和的函数
	int s = 0;
	for (int i=1; i<m; i++) s+=i;
	return s;
}
// 根据骨牌上的两个数字将其转换为对应的b_id
int trans_numbers_bid(int number1, int number2) {	
	int addd(int);		
	int less = number1 < number2 ? number1 : number2, more = number1 + number2 - less;
	int b_id = less*N+more;
	if (less>1) b_id-=addd(less);
	return b_id;
}

// Dominosa棋盘类
class Dominosa{
public:
	Dominosa(){};				// 构造函数
	Dominosa(const Dominosa&);	// 拷贝函数
	~Dominosa(){};				// 析构函数
	Single lattice[31][32];		// 第i行第j列的格子位置为:k=21*i+j,支持的最大数字 N=30
	bridge b[31*32/2];
	void init_connect();		// 初始化所有格子的up、down、left、right
	int sum_of_up_down_left_right(int m, int n); // 计算上下左右的和
	int sequence = 1;
};
Dominosa:: Dominosa(const Dominosa& dd) {
	for (int i=0; i<21; i++) {
		for (int j=0; j<22; j++) {
			this->lattice[i][j] = dd.lattice[i][j];
		}
	}
	for (int i=0; i<(N+1)*(N+2)/2; i++) {
		this->b[i].used = dd.b[i].used;
	}
	this -> sequence = dd.sequence;
}
void Dominosa:: init_connect(){
	// 初始化所有格子的up、down、left、right
	for (int j=0; j<N+2; j++) {
		lattice[0][j].up = 0;
		lattice[N][j].down = 0;
	}
	for (int i=0; i<N+1; i++) {
		lattice[i][0].left = 0;
		lattice[i][N+1].right = 0;
	}
	// 初始化 bridge
	for (int i=0; i<(N+1)*(N+2)/2; i++) {
		b[i].used = false;
	}
}
// 计算当前格与上下左右可能性的和,m是行数,n是列数
int Dominosa:: sum_of_up_down_left_right(int m, int n){
	// 如果是边缘格子,单独考虑
	if (m==0) {
		if (n==0) {
			return lattice[m][n].right+lattice[m][n].down;
		}
		else if (n==N+1) {
			return lattice[m][n].left+lattice[m][n].down;
		}
		else {
			return lattice[m][n].left+lattice[m][n].right+lattice[m][n].down;
		}
	}
	else if (m==N) {
		if (n==0) {
			return lattice[m][n].up+lattice[m][n].right;
		}
		else if (n==N+1) {
			return lattice[m][n].left+lattice[m][n].up;
		}
		else {
			return lattice[m][n].left+lattice[m][n].right+lattice[m][n].up;
		}
	}
	else {
		if (n==0) {
			return lattice[m][n].right+lattice[m][n].up+lattice[m][n].down;
		}
		else if (n==N+1) {
			return lattice[m][n].left+lattice[m][n].up+lattice[m][n].down;
		}
		else {
			return lattice[m][n].up+lattice[m][n].down+lattice[m][n].left+lattice[m][n].right;
		}
	}
}

// 求解 Dominosa 谜面,并调用print函数输出解
int D_solve(Dominosa D) {		// 返回-1,表示无解;返回0,表示可能有解,但需要BFS进一步计算;返回1,表示成功解出。

	void print_solution(Dominosa);
	void print_solution_in_file(Dominosa);

	int count_of_bridges = (N+1)*(N+2)/2;
	bool update = true;
	while (update) {
		update = false;
		
		// 初始化bridge.count
		for (int i=0; i<count_of_bridges; i++) {
			D.b[i].count = 0;
		}
		// 全面扫描D,更新bridge.count
		// 先横向扫描一遍,更新bridge.count
		for (int i=0; i<N+1; i++) {
			for (int j=0; j<N+1; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i][j+1].con==0) {
					D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].count++;
				}
			}
		}
		// 再纵向扫描一遍,更新bridge.count
		for (int i=0; i<N; i++) {
			for (int j=0; j<N+2; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i+1][j].con==0) {
					D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].count++;
				}
			}
		}
		// 全面扫描一遍,检查是否有四面都连接不了的格子,如果有,直接返回-1
		for (int i=0; i<N+1; i++) {
			for (int j=0; j<N+2; j++) {
				if (D.lattice[i][j].con==0 && D.sum_of_up_down_left_right(i, j)==0) {
					return -1;
				}
			}
		}

		// 从左向右扫描一遍,并尝试向右建立连接
		for (int i=0; i<N+1; i++) {
			for (int j=0; j<N+1; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i][j+1].con==0) {
					if (D.sum_of_up_down_left_right(i, j)==1 && D.lattice[i][j].right==1) {
						D.lattice[i][j].con = 1;
						D.lattice[i][j].sequ = D.sequence;
						D.lattice[i][j+1].con = 1;
						D.lattice[i][j+1].sequ = D.sequence;
						D.sequence++;
						D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used = true;
						update = true;
					}
					if (D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==false
						&& D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].count==1) {
							D.lattice[i][j].con = 1;
							D.lattice[i][j].sequ = D.sequence;
							D.lattice[i][j+1].con = 1;
							D.lattice[i][j+1].sequ = D.sequence;
							D.sequence++;
							D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used = true;
							update = true;
					}
				}
			}
		}
		// 从右向左扫描一遍,并尝试向左建立连接
		for (int i=0; i<N+1; i++) {
			for (int j=1; j<N+2; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i][j-1].con==0) {
					if (D.sum_of_up_down_left_right(i, j)==1 && D.lattice[i][j].left==1) {
						D.lattice[i][j].con = 1;
						D.lattice[i][j].sequ = D.sequence;
						D.lattice[i][j-1].con = 1;
						D.lattice[i][j-1].sequ = D.sequence;
						D.sequence++;
						D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used = true;
						update = true;
					}
					if (D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==false
						&& D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].count==1) {
							D.lattice[i][j].con = 1;
							D.lattice[i][j].sequ = D.sequence;
							D.lattice[i][j-1].con = 1;
							D.lattice[i][j-1].sequ = D.sequence;
							D.sequence++;
							D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used = true;
							update = true;
					}
				}
			}
		}
		// 从上向下扫描一遍,并尝试向下建立连接
		for (int i=0; i<N; i++) {
			for (int j=0; j<N+2; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i+1][j].con==0) {
					if (D.sum_of_up_down_left_right(i, j)==1 && D.lattice[i][j].down==1) {
						D.lattice[i][j].con = 1;
						D.lattice[i][j].sequ = D.sequence;
						D.lattice[i+1][j].con = 1;
						D.lattice[i+1][j].sequ = D.sequence;
						D.sequence++;
						D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used = true;
						update = true;
					}
					if (D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==false
						&& D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].count==1) {
							D.lattice[i][j].con = 1;
							D.lattice[i][j].sequ = D.sequence;
							D.lattice[i+1][j].con = 1;
							D.lattice[i+1][j].sequ = D.sequence;
							D.sequence++;
							D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used = true;
							update = true;
					}
				}
			}
		}
		// 从下向上扫描一遍,并尝试向上建立连接
		for (int i=1; i<N+1; i++) {
			for (int j=0; j<N+2; j++) {
				if (D.lattice[i][j].con==0 && D.lattice[i-1][j].con==0) {
					if (D.sum_of_up_down_left_right(i, j)==1 && D.lattice[i][j].up==1) {
						D.lattice[i][j].con = 1;
						D.lattice[i][j].sequ = D.sequence;
						D.lattice[i-1][j].con = 1;
						D.lattice[i-1][j].sequ = D.sequence;
						D.sequence++;
						D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used = true;
						update = true;
					}
					if (D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==false
						&& D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].count==1) {
							D.lattice[i][j].con = 1;
							D.lattice[i][j].sequ = D.sequence;
							D.lattice[i-1][j].con = 1;
							D.lattice[i-1][j].sequ = D.sequence;
							D.sequence++;
							D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used = true;
							update = true;
					}
				}
			}
		}

		// 全面更新D的每个con=0格子的up、down、left、right状态
		// 如果相邻的格子的con=1,则将其方向设置为0
		// 如果相邻的格子的con=0,但bridge.used=true,也要将其方向设置为0
		{
			int i=0;
			{
				int j=0;
				if (D.lattice[i][j].con==0) {
					if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
						D.lattice[i][j].right = 0;
					}
					if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
						D.lattice[i][j].down = 0;
					}
				}
				for (j=1; j<N+1; j++) {
					if (D.lattice[i][j].con==0) {
						if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
							D.lattice[i][j].left = 0;
						}
						if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
							D.lattice[i][j].right = 0;
						}
						if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
							D.lattice[i][j].down = 0;
						}
					}
				}
				j = N+1;
				if (D.lattice[i][j].con==0) {
					if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
						D.lattice[i][j].left = 0;
					}
					if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
						D.lattice[i][j].down = 0;
					}
				}
			}

			{
				for (i=1; i<N; i++) {
					int j=0;
					if (D.lattice[i][j].con==0) {
						if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
							D.lattice[i][j].right = 0;
						}
						if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
							D.lattice[i][j].up = 0;
						}
						if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
							D.lattice[i][j].down = 0;
						}
					}
					for (j=1; j<N+1; j++) {
						if (D.lattice[i][j].con==0) {
							if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
								D.lattice[i][j].left = 0;
							}
							if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
								D.lattice[i][j].right = 0;
							}
							if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
								D.lattice[i][j].up = 0;
							}
							if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
								D.lattice[i][j].down = 0;
							}
						}
					}
					j = N+1;
					if (D.lattice[i][j].con==0) {
						if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
							D.lattice[i][j].left = 0;
						}
						if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
							D.lattice[i][j].up = 0;
						}
						if (D.lattice[i+1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i+1][j].number)].used==true ) {
							D.lattice[i][j].down = 0;
						}
					}
				}
			}

			{
				i = N;
				int j=0;
				if (D.lattice[i][j].con==0) {
					if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
						D.lattice[i][j].right = 0;
					}
					if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
						D.lattice[i][j].up = 0;
					}
				}
				for (j=1; j<N+1; j++) {
					if (D.lattice[i][j].con==0) {
						if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
							D.lattice[i][j].left = 0;
						}
						if (D.lattice[i][j+1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j+1].number)].used==true ) {
							D.lattice[i][j].right = 0;
						}
						if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
							D.lattice[i][j].up = 0;
						}
					}
				}
				j = N+1;
				if (D.lattice[i][j].con==0) {
					if (D.lattice[i][j-1].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i][j-1].number)].used==true ) {
						D.lattice[i][j].left = 0;
					}
					if (D.lattice[i-1][j].con==1 || D.b[trans_numbers_bid(D.lattice[i][j].number, D.lattice[i-1][j].number)].used==true ) {
						D.lattice[i][j].up = 0;
					}
				}
			}
		}
	}

	int fbi=-1, fbj=-1;
	// 检测是否已经成功解出,如果未解出,标记第一个未连接的格子
	bool if_solve = true;
	for (int i=0; i<N+1; i++) {
		for (int j=0; j<N+2; j++) {
			if (D.lattice[i][j].con==0) {
				fbi = i;
				fbj = j;
				if_solve = false;
				break;
			}
		}
		if (if_solve==false) break;
	}

	// 如果已经解出,则返回true
	if (if_solve==true) {
		print_solution(D);	// 输出到命令行中
		// print_solution_in_file(D);	// 输出到文件 output.txt 中
		return 1;
	}
	
	// 否则用BFS求解(其实用的是递归啦哈哈)
	Dominosa d1(D), d2(D);
	// 设置d1为向右连接
	d1.lattice[fbi][fbj  ].con = 1;	d1.lattice[fbi][fbj  ].sequ = d1.sequence;
	d1.lattice[fbi][fbj+1].con = 1;	d1.lattice[fbi][fbj+1].sequ = d1.sequence;
	d1.sequence++;
	d1.b[trans_numbers_bid(d1.lattice[fbi][fbj].number, d1.lattice[fbi][fbj+1].number)].used = true;
	int solve_d1 = D_solve(d1);
	if (solve_d1==1) {
		return 1;
	}

	// 设置d2为向下连接
	d2.lattice[fbi  ][fbj].con = 1; d2.lattice[fbi  ][fbj].sequ = d2.sequence;
	d2.lattice[fbi+1][fbj].con = 1; d2.lattice[fbi+1][fbj].sequ = d2.sequence;
	d2.sequence++;
	d2.b[trans_numbers_bid(d2.lattice[fbi][fbj].number, d2.lattice[fbi+1][fbj].number)].used = true;
	int solve_d2 = D_solve(d2);
	if (solve_d2==1) {
		return 1;
	}

	return 0;
}

// 在命令行中输出最终的结果
void print_solution(Dominosa D) {
	for (int i=0; i<N+1; i++) {
		for (int j=0; j<N+2; j++) {
			cout << setw(4) << D.lattice[i][j].sequ;
		}
		cout << endl;
	}
}

// 将结果输出到 output.txt 中
void print_solution_in_file(Dominosa D) {
	fstream f;
	f.open("output.txt", ios::out|ios::app);
	f << endl; // 如果output.txt中本身已经有内容了,可以将其区分开,避免混淆

	for (int i=0; i<N+1; i++) {
		for (int j=0; j<N+2; j++) {
			f << setw(4) << D.lattice[i][j].sequ;
		}
		f << endl;
	}
	f.close();
}

Dominosa DMNS;				// 基础盘面DMNS
int main() {
	
	int trans_numbers_bid(int, int);
	int D_solve(Dominosa);

	// 初始化谜面
	DMNS.init_connect();

    freopen("input.txt","r",stdin);		// 谜面放在 input.txt 中
    //读入待解盘面D
	scanf("%d\n", &N);
	char c;
	for (int i=0; i<N+1; i++) {
		for (int j=0; j<N+2; j++) {
			scanf("%c", &c);
			DMNS.lattice[i][j].number = c - '0';
			DMNS.lattice[i][j].con = 0;
		}
		scanf("%*c");
	}
	
	int r = D_solve(DMNS);
	
    return 0;
}

现在的代码应该能够做到求解出每一个 Dominosa 谜题的答案,当然,你得确保谜题本身有解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/991245.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

canape中快速配置需要录制参数的技巧

以前在车里录制数据时&#xff0c;大量融合数据一个一个拖拽 &#xff0c;不仅慢&#xff0c;有时心不细的话&#xff0c;还会漏选、挑错。 用正则表达式的挑选方法&#xff0c;可以既快速又准确的挑出所需数据。 以下蓝色字体是操作方法&#xff1a; 正则表达式 示例&#xff…

QTableView通过setColumnWidth设置了列宽无效的问题

在用到QT的QTableView时&#xff0c;为了显示效果&#xff0c;向手动的设置每一列的宽度&#xff0c;但是如下的代码是无效的。 ui->tableView->setColumnWidth(0,150);ui->tableView->setColumnWidth(1,150);ui->tableView->setColumnWidth(2,150);ui->t…

docker-compose安装nginx

基于docker-compose安装nginx 目录 一、目录结构 1、docker-compose.yml 2、nginx.conf 3、default.conf 4、index.html 二、访问测试 一、目录结构 1、docker-compose.yml version: 3 services:nginx:image: registry.cn-hangzhou.aliyuncs.com/zhengqing/nginx:1.21.1…

Linux指令二【进程,权限】

进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程&#xff0c;是操作系统进行 资源分配和调度的一个独立单位&#xff0c;是应用程序运行的载体。 一、进程基本指令 1.ps&#xff1a;当前的用户进程 ps 只显示隶属于自己的进程状态ps -aux 显示所有进程…

C/C++计算(a+b)c的值 2019年9月电子学会青少年软件编程(C/C++)等级考试一级真题答案解析

目录 C/C计算(ab)c的值 一、题目要求 1、编程实现 2、输入输出 二、解题思路 1、案例分析 三、程序代码 四、程序说明 五、运行结果 六、考点分析 C/C计算(ab)c的值 2019年9月 C/C编程等级考试一级编程题 一、题目要求 1、编程实现 给定3个整数a、b、c&#xff0…

错误: 找不到或无法加载主类 Main

在用git回退到上个版本后发现&#xff0c;无法运行项目并提示 错误: 找不到或无法加载主类 Main 可以看到Main前面的图标也是号。 查了半天没有解决&#xff0c;问了个大佬&#xff0c;大佬一下就解决掉了&#xff0c;本文记录下解决过程。 错误原因是编辑器无法找到代码位置&…

java(五)继承和多态,抽象类与接口,异常(javaSE完)

八、继承和多态&#xff08;重要&#xff09; 对于java来说&#xff0c;最重要的就是面对对象&#xff0c;而如何体现这个&#xff0c;在其中三个概念极为重要&#xff0c;封装、继承、多态而无论考试还是面试通常都会考察这几个概念及其原理用法。 1.继承 面向对象思想中提…

Java“牵手”淘宝商品详情数据,淘宝商品详情API接口,淘宝API接口申请指南

淘宝平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取淘宝商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xff0c;通过…

Windows 安装 MariaDB 数据库

之前一直使用 MySQL&#xff0c;使用 MySQL8.0 时候&#xff0c;占用内存比较大&#xff0c;储存空间好像也稍微有点大&#xff0c;看到 MariaDB 是用来代替 MySQL 的方案&#xff0c;之前用着也挺得劲&#xff0c;MySQL8.0 以上好像不能去导入低版本的 sql&#xff0c;或者需要…

MySQL下载安装环境变量配置,常用命令

一、下载安装 mysql官网 下载连接 这个是下载图形安装 https://dev.mysql.com/downloads/installer/ 这个是下载免图形安装 https://dev.mysql.com/downloads/mysql/ 担心个别宝宝没有账号&#xff0c;这边也提供一下&#xff0c;方便下载&#xff1a; 账户&#xff1a;1602404…

宝兰德部署包特别慢部署超时失败问题解决

部署慢问题解决&#xff1a; 默认这块是空的&#xff0c;我改成 G1好像就快了。 刚开始是部署超时也是基于第一个问题的原因&#xff0c;如果你还有其他原因&#xff0c;但是查看服务日志一直显示超时&#xff0c;那可能是你看错日志文件了。 宝兰德操作日志 /data/besapp…

Matlab图像处理-迭代式阈值选择法

基本思想 迭代式阈值选择法的基本思想是&#xff1a;开始时&#xff0c;选择一个阈值作为初始估计值&#xff0c;然后按某种策略不断地改进这一估计值&#xff0c;直到满足给定的准则为止。在迭代过程中&#xff0c;关键之处在于选择什么样的阈值改进策略。好的阈值改进策略应…

学生免费申请IDEA使用流程

IntelliJ IDEA一般简称IDEA&#xff0c;是Java编程语言开发的集成环境&#xff0c;在业界被公认为最好的Java开发工具。 1 IDEA官网下载 1.1 官网地址 https://www.jetbrains.com/idea/ 1.2 IDEA下载 访问官网&#xff0c;单击download按钮&#xff0c;下载“IntelliJ IDE…

【疑难杂症】使用xshell连接云服务器连接不上

目录 【1】使用xshell连接云服务器连接不上 【1.1】解决方法一 【1.2】解决方法二 【1】使用xshell连接云服务器连接不上 Centos7使用xshell连接提示"ssh服务器拒绝了密码 请再试一次"。 问题如图所示&#xff0c;新安装了一台Centos7服务器&#xff0c;使用ssh连…

200行代码实现canvas九宫格密码锁

现在很多app&#xff0c;在一些隐私页面&#xff0c;往往都会加入二次验证&#xff0c;例如银行app、支付宝理财和我的页面&#xff0c;一般会有「九宫格密码」和指纹密码。 今天我们用canvas来写一个九宫格手势密码锁&#xff0c;大概就是下面这样。 思路 准备一个正方形画布…

四、子向父传值,展示项目经验

简介 发布订阅消息,子向父传值,展示项目经验详细信息。欢迎访问个人的简历网站预览效果 本章涉及修改与新增的文件:Fifth.vue、App.vue、utils、Project.ts 一、创建项目数据 在 src 目录下新建一个 utils 文件夹 ,再创建一个 Project.ts 文件 // 项目经验的详细数据 c…

day56补

583. 两个字符串的删除操作 力扣题目链接(opens new window) 给定两个单词 word1 和 word2&#xff0c;找到使得 word1 和 word2 相同所需的最小步数&#xff0c;每步可以删除任意一个字符串中的一个字符。 示例&#xff1a; 输入: "sea", "eat"输出: …

手撕 队列

队列的基本概念 只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有先进先出 入队列&#xff1a;进行插入操作的一端称为队尾 出队列&#xff1a;进行删除操作的一端称为队头 队列用链表实现 队列的实现 队列的定义 队列…

Java(三)逻辑控制(if....else,循环语句)与方法

逻辑控制&#xff08;if....else&#xff0c;循环语句&#xff09;与方法 四、逻辑控制1.if...else(常用)1.1表达格式&#xff08;三种&#xff09; 2.switch...case(用的少)2.1表达式 3.while(常用)3.1语法格式3.2关键字beak&#xff1a;3.3关键字 continue&#xff1a; 4.for…

RedisJava基础代码实现

Jedis快速入门 <!--jedis--> <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.7.0</version> </dependency> <!--单元测试--> <dependency><groupId>org.ju…