C ++, 926 bytes
#include<iostream>
#include<string>
#include<math.h>
#define S string
using namespace std;S N(S x,int y){S z="";for(int q=0;q<y;q++){z+=x;}return z;}int main(){int n=0,t=0,g=0,fi=1;cin>>n;int t1[]={0,0,n,0};int t2[]={0,n-2,n-2,1};for(int k=0;k<n+1;k++){if((k>(n-2)/2)&&(k<(n+5)/2)){if(g==0){S d,e;if(!((n+1)%4)){cout<<N("* ",t2[0])<<" *"<<N(" *",t2[0])<<endl<<N("* ",(n+1)/2)<<endl<<N("* ",t2[0])<<"***"<<N(" *",t2[0])<<endl;t2[2]=n-8-(n-11);t1[2]=n-4-(n-11);t1[0]--;t2[3]--;t1[3]-=2;}else{cout<<N("* ",t1[0])<<"***"<<N(" *",t2[0])<<endl<<N("* ",(n+1)/2)<<endl<<N("* ",t1[0])<<"* "<<N(" *",t2[0])<<endl;t2[0]--;t1[2]+=2;t2[2]+=6;t1[3]--;t2[1]-=2;t2[3]-=2;}fi=0;}g=5;}else{t=1-t;int*tR;tR=t?t1:t2;cout<<N("* ",tR[0])<<N(t?"*":" ",tR[2])<<N(" *",tR[3])<<endl;if(fi){if(t){t1[0]+=k==0?0:1;t1[2]-=k==0?2:4;t1[3]++;}else{t2[0]++;t2[2]-=4;t2[3]++;}}else{if(t){t1[0]--;t1[2]+=4;t1[3]--;}else{t2[0]--;t2[2]+=4;t2[3]--;}}}}return 0;}
Esto no es elegante, pero no ocupa mucha memoria para grandes n. Además, hay (casi con certeza) alrededor de 20 personajes que se pueden jugar más, pero no puedo soportar verlo más.
Breve explicación:
Esto divide las líneas en las espirales en dos tipos: las que tienen ****** en el medio y las que tienen \ s \ s \ s \ s \ s en el medio. Entonces está claro que cada línea está compuesta por varios "*", el medio y algunos "*". Averiguar exactamente cuántas de cada cosa es simple si observa el patrón durante el tiempo suficiente. Lo complicado fue imprimir el centro de la espiral, que básicamente codifiqué usando un condicional. Esto terminó siendo útil porque las líneas *** y \ s \ s \ s cambian siendo impares / pares allí.
Pruebas:
Entrada: 55 (creo que los grandes se ven más geniales)
Salida:
************************************************** *****
* *
************************************************** *** *
* * *
* ************************************************* * *
* * * * *
* * ********************************************* * * *
* * * * * * *
* * * ***************************************** * * * *
* * * * * * * * *
* * * * ************************************* * * * * *
* * * * * * * * * * *
* * * * * ********************************* * * * * * *
* * * * * * * * * * * * *
* * * * * * ***************************** * * * * * * *
* * * * * * * * * * * * * * *
* * * * * * * ************************* * * * * * * * *
* * * * * * * * * * * * * * * * *
* * * * * * * * ********************* * * * * * * * * *
* * * * * * * * * * * * * * * * * * *
* * * * * * * * * ***************** * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * ************* * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * ********* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * ***** * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * {- mi programa agrega un espacio aquí por cierto
* * * * * * * * * * * * * *** * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * ******* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * *********** * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * *************** * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * *
* * * * * * * * * ******************* * * * * * * * * *
* * * * * * * * * * * * * * * * * *
* * * * * * * * *********************** * * * * * * * *
* * * * * * * * * * * * * * * *
* * * * * * * *************************** * * * * * * *
* * * * * * * * * * * * * *
* * * * * * ******************************* * * * * * *
* * * * * * * * * * * *
* * * * * *********************************** * * * * *
* * * * * * * * * *
* * * * *************************************** * * * *
* * * * * * * *
* * * ******************************************* * * *
* * * * * *
* * *********************************************** * * *
* * * *
* ************************************************* ** *
* *
************************************************** *****
Entrada: 3
Salida:
***
* *
* *
***
Nota: No soy un estudiante de informática / CS, y no sé cómo demostrar que esto usa memoria O (log n). Solo puedo averiguar qué hacer en función de los enlaces de la pregunta. Estaría agradecido si alguien pudiera confirmar / negar si esta respuesta es válida. Mi lógica para la validez de esta respuesta es que nunca almacena ninguna variable de tamaño basada en n, excepto la entrada en sí. En cambio, un bucle for que se ejecuta n veces calcula valores enteros basados en n. Hay el mismo número de esos valores independientemente de la entrada.
Nota 2: Esto no funciona para n = 1 debido a mi método de tratar con el medio. Esto sería fácil de solucionar con condicionales, así que si alguien está dentro de unos pocos caracteres de mi respuesta, lo arreglaré;)
Juega con él en ideone.
nen la memoria O (1).