#include <bits/stdc++.h>
using namespace std;
int n,m;
long long ans;
int k;
bool flag[100][100];
long long ma[100][100];
int louti;
long long a[100];
int loading()
{
int i=0,j=0;
while(1)
{
cin>>flag[i][j];
cin>>ma[i][j];
if(j/(m-1)==1)
{
i++;
j=0;
}
else
{
j++;
}
if(i==n)
{
cin>>k;
break;
}
}
}
int main()
{
cin>>n>>m;
loading();
for(int i=0;i<=n-1;i++)
{
for(int j=0;j<=m-1;j++)
{
if(flag[i][j]==true)
a[i]+=1;
else
a[i]+=0;
}
}
int o=0;
int xh,l;
while(1)
{
xh=ma[o][k];
ans+=ma[o][k];
l=xh%a[o];
for(int p=m-1;p>=0;p--)
{
if(flag[o][p]==true)
l--;
else
l+=0;
if(l==0||l==-1)
{
k=p;
o++;
break;
}
}
if(o==n)
break;
}
cout<<ans%20123;
return 0;
}