#include <iostream>
using namespace std;
int nextt[1000000];
string a,b;//文本串,模式串
void GetNext(int m)
{
nextt[0]=-1;
int i=-1;
int j=0;
while(j<m)
{
if(i==-1||b[i]==b[j])
{
i++;j++;
nextt[j]=i;
}
else {
i=nextt[i];
}
}
}
int KMP(int m,int n)
{
int i=0;//文本串
int j=0;//模式串
int num=0;
GetNext(m);
while(i<n)
{
if(a[i]==b[j]||j==-1)
{
i++;j++;
}
else {
j=nextt[j];
}
if(j==m)//模式串的下标最大为m-1,j必须重新赋值
{
num++;
j=nextt[j];
}
}
return num;
}
int main() {
while (cin >> a >> b) {
int n=a.size();
int m=b.size();
int num=KMP(m,n);
cout<<num<<endl;
}
}