#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pi (4*atan(1.0))
#define eps 1e-14
const int N=2e5+10,M=4e6+10,inf=1e9+10,mod=1e9+7;
const ll INF=1e18+10;
int n,m,k;
char mp[60][60];
int xx[4]={1,0,-1,0};
int yy[4]={0,-1,0,1};
int vis[60][60];
int p[N];
struct is
{
int si;
int pos;
/*bool operator <(const is &b)const
{
if(p[pos]!=p[b.pos])
return p[pos]<p[b.pos];
return si>b.si;
}*/
}a[N];
int cmp(is a,is b)
{
if(p[a.pos]!=p[b.pos])
return p[a.pos]<p[b.pos];
return a.si>b.si;
}
int check(int x,int y)
{
if(x>=n||x<0||y>=m||y<0) return 0;
return 1;
}
void dfs(int x,int y,int z)
{
vis[x][y]=z;
for(int i=0;i<4;i++)
{
int xxx=x+xx[i];
int yyy=y+yy[i];
if(check(xxx,yyy)&&mp[xxx][yyy]=='.'&&!vis[xxx][yyy])
{
dfs(xxx,yyy,z);
}
}
}
int main()
{
scanf("%d%d%d",&n,&m,&k);
for(int i=0;i<n;i++)
scanf("%s",mp[i]);
int flag=1;
for(int i=0;i<n;i++)
{
for(int t=0;t<m;t++)
{
if(mp[i][t]=='.'&&!vis[i][t])
dfs(i,t,flag++);
}
}
for(int i=1;i<flag;i++)
a[i].pos=i,a[i].si=0;
for(int i=0;i<n;i++)
{
for(int t=0;t<m;t++)
{
if(vis[i][t]>0)
{
a[vis[i][t]].si++;
if(i==0||i==n-1||t==0||t==m-1)
p[vis[i][t]]=1;
}
}
}
sort(a+1,a+flag,cmp);
int ans=0;
for(int i=1;i<flag;i++)
{
if(p[a[i].pos]==0&&i>k)
ans+=a[i].si;
}
for(int i=1;i<=k;i++)
p[a[i].pos]=1;
printf("%d\n",ans);
for(int i=0;i<n;i++)
{
for(int t=0;t<m;t++)
{
if(vis[i][t]>0)
{
if(p[vis[i][t]])
printf(".");
else
printf("*");
}
else
printf("*");
}
printf("\n");
}
return 0;
}