#include <iostream>
using namespace std;
char mine[105][105];
int num[105][105];
int n, m;
int main(){
cin >> n >> m;
/*下面的步骤是:首先是n行m列,我们定义了一个char的数组和一个int的数组
每一次都会输入一个字符,用mine来装,如果这个字符是*,说明这个位置是炸弹
那么炸弹的上下左右、左上、左下、右上、右下位置都会加1,此时我们用num数组
来装这些位置的值*/
for(int i=0; i<n; i++)
for(int j=0; j<m; j++){
cin >> mine[i][j];
if(mine[i][j] == '*'){
num[i-1][j]++;
num[i-1][j]++;
num[i][j-1]++;
num[i][j+1]++;
num[i-1][j-1]++;
num[i+1][j-1]++;
num[i-1][j+1];
num[i+1][j+1];
}
}
/*如果这个位置的mine是*,那么就直接输出这个位置的mine,否则输出num*/
for(int i=0; i<n; i++){
for(int j=0; j<m; j++)
if(mine[i][j] == '*')
cout << mine[i][j];
else
cout << num[i][j];
cout << endl;
}
return 0;
}