# Karpet Ribet ## Brief ## Solution ```c= //by Mary Madeline #include <stdio.h> int array [3100][3100]; void karpetRibet(int x, int y, int n){ if(n==0)return; int h = n/2; for(int i=0;i<n;i++){ for(int j=0;j<n;j++){ array[x+i][y+j]=1; } } karpetRibet(x-h,y-h,h); karpetRibet(x-h,y+n,h); karpetRibet(x+n,y-h,h); karpetRibet(x+n,y+n,h); } int main() { int n; scanf("%d",&n); n--; int d=1<<n; // 2 to the power of n int span=(d-1)*2+d; // span of carpet for(int i=0;i<span;i++){ for(int j=0;j<span;j++){ array[i][j]=0; } } karpetRibet(d-1,d-1,d); for(int i=0;i<span;i++){ for(int j=0;j<span;j++){ if(array[i][j]==1) printf("*"); else printf(" "); } printf("\n"); } return 0; } ```