#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<queue>
#include<vector>
#include<stack>
#include<map>
#include<set>
#include<ctime>
#include<cstdlib>
#define ll long long
using namespace std;
const int constant=1e6+5;
string t,p;
int next[constant];
void build(string s){
next[1]=0;
int len=s.size();
int i=1,j=0;
while(i<len){
if(s[i]==s[j]){
j++;
next[i]=j;
i++;
}
else{
if(j){
j=next[j-1];
}
else{
next[i]=0;
i++;
}
}
}
}
int kmp(string t,string p){
int n=t.size();
int m=p.size();
build(p);
int i=0,j=0;
while(i<n){
if(t[i]==p[j]){
i++;
j++;
}
if(j==m){
return i-j;
}
else if(i<n&&t[i]!=p[j]){
if(j) j=next[j-1];
else i++;
}
}
return -1;
}
int main(){
cin>>t>>p;
while(1){
int k=kmp(t,p);
if(k==-1) break;
printf("%d\n",k+1);
t[k]='0';
}
for(int i=0;i<p.size();i++){
printf("%d ",next[i]);
}
return 0;
}