解题思路:
注意事项:
参考代码:
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
private static int min=99999;
private static ArrayList<tep> b=new ArrayList<>();
private static ArrayList<String> stat=new ArrayList<>();
public static void main(String[] args) {
Scanner input=new Scanner(System.in);
int m=input.nextInt();
char a[]=input.next().toCharArray();
tep tep=new tep();
tep.step=0;
tep.str=String.valueOf(a);
stat.add(tep.str);
b.add(tep);
boolean fign=false;
if(check(a))min=0;
else
while(b.size()!=0){
tep te=b.get(0);
char strs[]=te.str.toCharArray();
b.remove(0);
for (int i = 0; i <m; i++) {
if(i+1<m){
char c=strs[i];
strs[i]=strs[i+1];
strs[i+1]=c;
tep tes=new tep();
tes.step=te.step+1;
if(check(strs)){
min=tes.step;
fign=true;
break;
}
tes.str=String.valueOf(strs);
if(!stat.contains(String.valueOf(strs))){
stat.add(String.valueOf(strs));
b.add(tes);
}
c=strs[i];
strs[i]=strs[i+1];
strs[i+1]=c;
}
}
if(fign)break;
}
if(min!=99999)
System.out.println(min);
else{
System.out.println(-1);
}
}
private static boolean check(char[] a) {
String str=new String(a);
if(str.contains("2012"))return true;
return false;
}
}
class tep{
public int step;
public String str;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复