Difference between revisions of "Esercizi a caso del Prof."

From Sistemi Operativi
Jump to navigation Jump to search
Line 66: Line 66:
 
f="f={0}{1}{0};print(f.format(chr(34),f))";print(f.format(chr(34),f))
 
f="f={0}{1}{0};print(f.format(chr(34),f))";print(f.format(chr(34),f))
 
</syntaxhighlight>
 
</syntaxhighlight>
 +
 +
 +
*Ho provato a rendere ancora più corto il codice cercando di rimuovere l'assegnamento ma in realtà lo allunga.
 +
<syntaxhighlight lang="python">
 +
print('print({0!r}.format({0!r}))'.format('print({0!r}).format({0!r}))'))
 +
</syntaxhighlight>
 +
-Fede
  
 
=== Programmi semplici ===
 
=== Programmi semplici ===

Revision as of 06:10, 2 November 2013

Cominciamo da una sfida:

Il programma che stampa se stesso

scrivere un programma che produca in output se stesso: i.e. non prevede input e l'output deve essere identico al sorgente.

Vince chi produce il programma piu' compatto (in ogni linguaggio).

Però non dovete fare come in questo tentativo. il programma deve stampare se stesso senza leggere il proprio sorgente! (è proprio quella la sfida divertente!, rd 20131027). Per il Pyhton il programma vuoto non vale, è una soluzione banale. Ecco un altro tentativo errato.

  print(__file__) 

non e' non Quine in Python 3.x perché stampa il proprio parametro, non il proprio sorgente. In caso contrario anche il comando echo sarebbe un Quine!

  • [Python] beccatevi questo (da Federico A. e Alessio G.):
    La prima versione con due variabili
     a='a=%r;b=%r;print a%%(a,b)';b='b=%r;print a%%(a,b)';print a%(a,b)
    
    Per capire meglio la logica del format ci siamo sbizzarriti
     a = 'a = %r ; b = %r ; c = %r ; print a%%(a,b,c) ' ; b = 'b = %r ; c = %r ; print a%%(a,b,c) ' ; c = 'c = %r ; print a%%(a,b,c) ' ; print a%(a,b,c)
    
  1. %% fuori stringa corrisponde ad un solo %.
  2. print a%(a,b,c) corrisponderebbe in C a printf(a,a,b,c).
  • [C] beccatevi anche questo (da Alessio G. e Federico A.):

Usando la stessa logica del programma in "pitone" lo abbiamo rielaborato in C:

/*Printf stampa la stringa s e sostituisce ad ogni occorrenza di %c i caratteri ascii corrispondenti ai numeri: 9 = \t , 10 = \n , 34 = \"  .
Il %s corrisponde alla stringa.*/
#include <stdio.h>
	char s[] = "#include <stdio.h>%c%cchar s[]=%c%s%c;%cvoid main(void){%c%cprintf(s,10,9,34,s,34,10,9,10,9,10);%c%c}%c";
void main(void){
       printf(s,10,9,34,s,34,10,10,9,10,9,10);  
	}

(bravi Alessio e Federico, questi sono proprio Quine!, rd 20131101)

  • [Python3] (io ho fatto un Quine in python3 con il metodo format... perché non ci provate ache voi? rd20131101)



  • Grazie a questa pagina Advanced String Formatting ho scoperto che con !r è possibile usare la funzione repr() solo su certi fields della stringa il che era l'ultimo bit che mi mancava per riuscirci.
a='a={0!r}{1}print(a.format(a,{1!r}))'
print(a.format(a,'\n'))

-Fede

  • Come non detto facendo qualche esperimento sono riuscito a compattarla ancora di più
a='a={0};print(a.format(repr(a)))';print(a.format(repr(a)))

oppure 10 caratteri in meno:

a='a={0!r};print(a.format(a))';print(a.format(a))

Questo codice funziona sia in python 3 che 2.

  • questo invece è il mio primo tentativo sbagliato ma che ha messo in evidenza la differenza tra % e .format.
a='a={0}\nprint(a.format(a))'
print(a.format(a))

-Fede

Ottimo Fede, il tuo Quine e' anche piu' corto del mio. Io usavo la funzione chr, ma il formato !r toglie ancora qualche carattere (rd 20131101):

f="f={0}{1}{0};print(f.format(chr(34),f))";print(f.format(chr(34),f))


  • Ho provato a rendere ancora più corto il codice cercando di rimuovere l'assegnamento ma in realtà lo allunga.
print('print({0!r}.format({0!r}))'.format('print({0!r}).format({0!r}))'))

-Fede

Programmi semplici

riscrivere le funzioni strcpy, strcmp, strncmp etc... (quelle elencate da "man 3 string") in C e in Python.

scrivere una funzione che controlli se una stringa e' palindroma (C python)

Una miniera di esercizi

Rosetta Stone. Tantissimi problemi risolti con tantissimi linguaggi.