1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
| public class Main{
static void addNumberToMap(int num,Map<Character,Integer> count){
for(char c:String.valueOf(num).toCharArray()){
count.put(c,count.getOrDefault(c,0)+1);
}
}
static void removeNumberFromMap(int num,Map<Character,Integer> count){
for(char c:String.valueOf(num).toCharArray()){
count.put(c,count.get(c)-1);
if(count.get(c)==0){
count.remove(c);
}
}
}
public static void main(String[] args){
Scanner scanner=new Scanner(System.in);
String s=scanner.next();
int k=scanner.nextInt();
scanner.close();
Mao<Character,Integer> base=new HashMap<>();
for(char c:s.toCharArray()){
base.put(c,base.getOrDeault(c,0)+1);
}
Map<Character,Integer> count=new HashMap<>();
for(int i=1;i<=k;i++){
addNumberToMap(i,count);
}
if(count.equals(base)){
System.out.println(1);
return;
}
for(int i=2;i<=1000-k+1;i++){
removeNumberFromMap(i-1,count);
addNumberToMap(i+k-1,count);
if(count.equals(base)){
System.out.println(i);
return;
}
}
}
}
|