C ++, 926 octets
#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;}
Ce n'est pas élégant, mais cela ne prend pas beaucoup de mémoire pour les grands n. De plus, il y a (presque certainement) environ 20 personnages qui peuvent être joués plus loin, mais je ne supporte plus de le regarder.
Brève explication:
Cela divise les lignes dans les spirales en deux types: celles avec ****** au milieu et celles avec \ s \ s \ s \ s \ s au milieu. Ensuite, il est clair que chaque ligne est composée de plusieurs "*", le milieu et quelques "*". Déterminer exactement combien de chaque chose est simple si vous regardez le motif assez longtemps. La chose délicate était d'imprimer le centre de la spirale que j'ai codé en dur à l'aide d'un conditionnel. Cela a fini par être utile parce que les lignes *** et \ s \ s \ s sont impaires / paires.
Tests:
Entrée: 55
(je pense que les grands sont les plus cool)
Production:
************************************************** *****
*
************************************************** *** *
* * *
* ************************************************* * *
* * * * *
* * ********************************************* * * *
* * * * * * *
* * * ***************************************** * * * *
* * * * * * * * * *
* * * * ************************************* * * * * *
* * * * * * * * * * *
* * * * * ********************************* * * * * * *
* * * * * * * * * * * * *
* * * * * * ***************************** * * * * * * *
* * * * * * * * * * * * * * * *
* * * * * * * ************************* * * * * * * * *
* * * * * * * * * * * * * * * * *
* * * * * * * * ********************* * * * * * * * * *
* * * * * * * * * * * * * * * * * * *
* * * * * * * * * ***************** * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * ************* * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * ********* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * ***** * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * {- mon programme ajoute un espace ici btw
* * * * * * * * * * * * * *** * * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * * ******* * * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * * *********** * * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * * * * *
* * * * * * * * * * *************** * * * * * * * * * *
* * * * * * * * * * * * * * * * * * * *
* * * * * * * * * ******************* * * * * * * * * *
* * * * * * * * * * * * * * * * * *
* * * * * * * * *********************** * * * * * * * *
* * * * * * * * * * * * * * * * *
* * * * * * * *************************** * * * * * * *
* * * * * * * * * * * * * * *
* * * * * * ******************************* * * * * * *
* * * * * * * * * * * *
* * * * * *********************************** * * * * *
* * * * * * * * * *
* * * * *************************************** * * * *
* * * * * * * * *
* * * ******************************************* * * *
* * * * * *
* * *********************************************** * *
* * * *
* ************************************************* ** *
* *
************************************************** *****
Contribution: 3
Production:
***
*
* *
***
Remarque: Je ne suis pas un informaticien / étudiant CS, et je ne sais pas comment prouver que cela utilise la mémoire O (log n). Je ne peux que savoir quoi faire en fonction des liens dans la question. Je vous serais reconnaissant de bien vouloir confirmer / infirmer si cette réponse est valide. Ma logique pour la validité de cette réponse est qu'elle ne stocke jamais aucune variable de taille basée sur n, sauf l'entrée elle-même. Au lieu de cela, une boucle for qui s'exécute n fois calcule des valeurs entières basées sur n. Il y a le même nombre de ces valeurs quelle que soit l'entrée.
Note2: Cela ne fonctionne pas pour n = 1 en raison de ma méthode de traitement avec le milieu. Ce serait facile à corriger avec les conditions, donc si quelqu'un se trouve à quelques caractères de ma réponse, je le corrigerai;)
Jouez avec lui sur ideone.
n
dans la mémoire O (1).