学习总结!

java目前学习到了类的实例化:

类:描述一种事物的定义,是抽象的概念

实例:该事物的一个具体的个体,是具体的东西

举例:

世界上人很多,可以定义一个Person类:

复制代码
Public Person
{
    Public String Name {get; set;}
    Public String Age {get; set;}
}

这是类的创建。

每个人又是有区别的,那我们就可以根据Person类来创建不同的人,比如说:

复制代码
Person p1 = New Person() { Name = "A", Age = "22" }
Person p2 = New Person() { Name = "B", Age = "23" }

这就是类的实例化。

用类的定义来创建一个实例,就叫做类的实例化。

用new语句创建对象,这是最常见的创建对象的方法。

算法题:

 输入测试用例数t,每个例子包括两个4个数字的整数(由1到9组成),一个为源,另外一个为目标。每次可以将其中任何一个数字+1或者-1运算,并且规定1-1=9,9+1=1;也可以将相邻2位数进行交换。问最少需要变换几次,才能从源变为目标 该问题可以用BFS来解决。在BFS搜索过程中,出现过的4位数就不必再试探了,因为再用这个4位数变下去其次数不可能比上次开始的变换次数少。

cpp 复制代码
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
char str[2][5];
int target[4];
struct node{
	int step;
	int a[4];
};
bool vis[10][10][10][10];
int bfs()
{
	node now,next1;
	for(int i=0;i<4;i++)
	{
		target[i]=str[1][i]-'0';
		now.a[i]=str[0][i]-'0';
	}
	memset(vis,false,sizeof(vis));
	queue<node>q;
	now.step=0;
	q.push(now);
	bool flag;
	while(q.size())
	{
		node now=q.front();
		q.pop();
		flag=true;
		for(int i=0;i<4;i++)
		{
			if(now.a[i]!=target[i])
			{
				flag=false;
				break;
			}
		}
		if(flag)
		{
			return now.step;
		}
		for(int i=0;i<4;i++)
		{
			next1=now;
			if(now.a[i]==9)
				next1.a[i]=1;
			else
				next1.a[i]=now.a[i]+1;
			if(!vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]])
			{
				vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]]=true;
				next1.step=now.step+1;
				q.push(next1);
			}
		}
		for(int i=0;i<4;i++)
		{
			next1=now;
			if(now.a[i]==1)
				next1.a[i]=9;
			else
				next1.a[i]=now.a[i]-1;
			if(!vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]])
			{
				vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]]=true;
				next1.step=now.step+1;
				q.push(next1);
			}
		}
		for(int i=0;i<3;i++)
		{
			next1=now;
			next1.a[i]=now.a[i+1];
			next1.a[i+1]=now.a[i];
			if(!vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]])
			{
				vis[next1.a[0]][next1.a[1]][next1.a[2]][next1.a[3]]=true;
				next1.step=now.step+1;
				q.push(next1);
			}
		}
	}
	return -1;
}
int main()
{
	int t;
	cin>>t;
	while(t--)
	{
		cin>>str[0]>>str[1];
		cout<<bfs()<<endl;
	}
	return 0;
}
相关推荐
YangYang9YangYan3 分钟前
2026学习数据分析对报考大数据专业的价值
大数据·学习·数据分析
speop5 分钟前
运行 Gemma4 大模型TASK01
学习
-To be number.wan5 分钟前
计算机组成原理 | 指令格式全解析
学习·计算机组成原理
KaMeidebaby10 分钟前
卡梅德生物技术快报|羊驼免疫:分子生物学实战:基于羊驼免疫的重链抗体制备与全流程验证方案
前端·网络·数据库·人工智能·算法·百度
oort12310 分钟前
AI+基层治理·智慧政务解决方案——AI民意速办智能助手
大数据·人工智能·算法·政务
MartinYeung524 分钟前
[论文学习]环境注入攻击(EIA)对通用网页代理的隐私洩露威胁
网络·学习
渡之28 分钟前
GeoBridge 深度解析:语义锚定多视图基础模型,重塑无人机跨视角地理定位
深度学习·算法·动态规划·无人机
一口吃俩胖子32 分钟前
【脉宽调制DCDC功率变换学习笔记024】电压反馈补偿和环路增益
笔记·学习·算法
洛水水36 分钟前
【力扣100题】80.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
ting945200037 分钟前
VC Boom 技术架构与核心算法深度解
人工智能·算法·架构