Chuck Norris vs commesso viaggiatore


19

introduzione

Quasi tutti hanno familiarità con il Traveller Salesman Problem (TSP). Il compito è, dato un elenco di Ncittà, trovare il ciclo hamiltoniano minimo , ovvero il percorso più breve che visita ogni città e torna al punto di partenza. Non è questa la sfida. Questa sfida è implementare la soluzione di Chuck Norris al TSP:

Chuck Norris ha risolto in O(1)tempo il problema del commesso viaggiatore : suddividere il commesso in N pezzi; calciare ogni pezzo in una città diversa.

Sfida

Per risolvere il TSP in questo modo, abbiamo bisogno di un commesso sufficientemente duraturo che non eviterà frivolezze come lo smembramento; un certo numero di città da visitare; un insieme di prodotti da vendere; un metodo concreto di smembramento; e un calcolo per il punteggio.

specificazione

  • Città
    • N è il numero di citazioni che il nostro venditore visiterà
  • Venditore
    • Il programma o la funzione principale
    • Scritto in lingua X
    • Con lunghezza mod Nuguale a0
  • Prodotti
    • I nomi completi degli elementi nella tavola periodica
    • Ciò include i nomi degli elementi appena accettati
  • Dismemberment
    • Affettare il commesso in Npezzi continui di uguale lunghezza
    • Ogni pezzo deve essere una funzione o un programma valido nella lingua X
  • Produzione
    • Quando eseguito, il venditore dovrebbe produrre Chuck Norrise i pezzi tagliati dovrebbero produrre ciascuno un prodotto distinto
    • È accettabile solo uno spazio bianco finale aggiuntivo
  • punteggio
    • La lunghezza Ldel venditore in byte divisa per il numero di città N, quadrata.
    • Score = L/(N*N)
    • Il punteggio più piccolo vince
    • Ti preghiamo di includere 3 cifre significative quando pubblichi il tuo punteggio decimale

Esempi

  1. Questo venditore visita 3 città così N=3e ha una lunghezza di 9 così L=9. Quindi il punteggio per questa risposta sarebbe S = 9 / (3 * 3) = 9/9 = 1.
    • Si noti che il venditore e ogni pezzo tagliato (di cui ce ne sono 3), dovrebbero essere tutti programmi o funzioni validi nella stessa lingua.
Program      -> Output
-------         ------
aaaBBBccc    -> Chuck Norris

aaa          -> Helium
BBB          -> Iridium
ccc          -> Tennessine
  1. N=4e L=20cosìS=20/16=1.25
Program                 -> Output
-------                    ------
aaaaaBBBBBcccccDDDDD    -> Chuck Norris

aaaaa                   -> Hydrogen
BBBBB                   -> Cadmium
ccccc                   -> Mercury
DDDDD                   -> Iron

3
Sono ElementDataammessi incorporati come quelli di Mathematica ? (Dubito che salverà molto, ma non lo so.)
Martin Ender,

La capitalizzazione degli output è importante?
Martin Ender,

1
@MartinEnder ^^ sì ^ sì
NonlinearFruit

6
Qualcuno degli elettori vicini potrebbe spiegare quale parte ritenga in realtà poco chiara? (So ​​che non possono essere solo le mie due domande, che non credo nemmeno debbano essere esplicitamente affrontate nella sfida, perché c'erano già voti stretti quando le ho postate.)
Martin Ender

2
Totalmente d'accordo con @MartinEnder. Se non ti piace una sfida, provane un'altra.
edc65,

Risposte:


11

CJam, L = 1482, N = 114, punteggio 0.114

'C:L"arbon"  L'h+:L;"Gold"L'u+:L;"Iron"L'c+:L;"Lead"L'k+:L;"Neon"LS+:L;"Argon"L'N+:L"ickel"L'o+:L;"Zinc""Coppe"L'r+:L"Silve"L'r+:LL'i+:L;"Tin" "Boron"      "Radon"      "Barium"     "Cerium"     "Cesium"     "Cobalt"     "Curium"     "Erbium"     "Helium"     "Indium"     "Iodine"     "Osmium"     "Oxygen"     "Radium"     "Sodium"     "Sulfur"     "Arsenic"    "Bismuth"    "Bohrium"    "Bromine"    "Cadmium"    "Calcium"    "Dubnium"    "Fermium"    "Gallium"    "Hafnium"    "Hassium"    "Holmium"    "Iridium"    "Krypton"    "Lithium"    "Mercury"    "Niobium"    "Rhenium"    "Rhodium"    "Silicon"    "Terbium"    "Thorium"    "Thulium"    "Uranium"    "Yttrium"    "Actinium"   "Aluminum"   "Antimony"   "Astatine"   "Chlorine"   "Chromium"   "Europium"   "Fluorine"   "Francium"   "Hydrogen"   "Lutetium"   "Nihonium"   "Nitrogen"   "Nobelium"   "Platinum"   "Polonium"   "Rubidium"   "Samarium"   "Scandium"   "Selenium"   "Tantalum"   "Thallium"   "Titanium"   "Tungsten"   "Vanadium"   "Americium"  "Berkelium"  "Beryllium"  "Flerovium"  "Germanium"  "Lanthanum"  "Magnesium"  "Manganese"  "Moscovium"  "Neodymium"  "Neptunium"  "Oganesson"  "Palladium"  "Plutonium"  "Potassium"  "Ruthenium"  "Strontium"  "Tellurium"  "Ytterbium"  "Zirconium"  "Dysprosium" "Gadolinium" "Lawrencium" "Meitnerium" "Molybdenum" "Phosphorus" "Promethium" "Seaborgium" "Technetium" "Tennessine" "Californium""Copernicium""Einsteinium""Livermorium""Mendelevium""Roentgenium"]L's+"Xenon"?

Provalo online!

Ogni programma ha una lunghezza di 13 byte. Qui sono suddivisi in singole righe:

'C:L"arbon"  
L'h+:L;"Gold"
L'u+:L;"Iron"
L'c+:L;"Lead"
L'k+:L;"Neon"
LS+:L;"Argon"
L'N+:L"ickel"
L'o+:L;"Zinc"
"Coppe"L'r+:L
"Silve"L'r+:L
L'i+:L;"Tin" 
"Boron"      
"Radon"      
"Barium"     
"Cerium"     
"Cesium"     
"Cobalt"     
"Curium"     
"Erbium"     
"Helium"     
"Indium"     
"Iodine"     
"Osmium"     
"Oxygen"     
"Radium"     
"Sodium"     
"Sulfur"     
"Arsenic"    
"Bismuth"    
"Bohrium"    
"Bromine"    
"Cadmium"    
"Calcium"    
"Dubnium"    
"Fermium"    
"Gallium"    
"Hafnium"    
"Hassium"    
"Holmium"    
"Iridium"    
"Krypton"    
"Lithium"    
"Mercury"    
"Niobium"    
"Rhenium"    
"Rhodium"    
"Silicon"    
"Terbium"    
"Thorium"    
"Thulium"    
"Uranium"    
"Yttrium"    
"Actinium"   
"Aluminum"   
"Antimony"   
"Astatine"   
"Chlorine"   
"Chromium"   
"Europium"   
"Fluorine"   
"Francium"   
"Hydrogen"   
"Lutetium"   
"Nihonium"   
"Nitrogen"   
"Nobelium"   
"Platinum"   
"Polonium"   
"Rubidium"   
"Samarium"   
"Scandium"   
"Selenium"   
"Tantalum"   
"Thallium"   
"Titanium"   
"Tungsten"   
"Vanadium"   
"Americium"  
"Berkelium"  
"Beryllium"  
"Flerovium"  
"Germanium"  
"Lanthanum"  
"Magnesium"  
"Manganese"  
"Moscovium"  
"Neodymium"  
"Neptunium"  
"Oganesson"  
"Palladium"  
"Plutonium"  
"Potassium"  
"Ruthenium"  
"Strontium"  
"Tellurium"  
"Ytterbium"  
"Zirconium"  
"Dysprosium" 
"Gadolinium" 
"Lawrencium" 
"Meitnerium" 
"Molybdenum" 
"Phosphorus" 
"Promethium" 
"Seaborgium" 
"Technetium" 
"Tennessine" 
"Californium"
"Copernicium"
"Einsteinium"
"Livermorium"
"Mendelevium"
"Roentgenium"
]L's+"Xenon"?

Gli elementi mancanti sono Darmstadtium, Praseodymium, Protactinium e Rutherfordium che sono lunghi 12 o 13 caratteri, il che significa che non posso stamparli in 13 caratteri ciascuno.

L'idea è che i primi pochi programmi, che stampano gli elementi con nomi brevi, usano i loro caratteri estranei per costruire la stringa Chuck Norrinella variabile L, il che non influisce sull'output se usati da soli. Il programma finale controlla quindi se qualcosa è già nello stack e lo utilizza per scegliere tra L(più s) e Xenon.

Alcuni byte aggiuntivi vengono salvati utilizzando il carattere che abbiamo appena aggiunto Lcome parte del nome dell'elemento, in particolare per Carbon, Nickel, Coppe re Silve r.


2

Python, L = 2596, N = 118, Punteggio = 0.186

La lunghezza di ogni fetta è 22, quindi è abbastanza lungo.

lambda:"Gold"; print"""";print "Carbon     "print   "Thorium     "print   "Curium      "print "Calcium       "print "Nickel        "print      "Zinc     "print    "Neon       "print "Boron         "print   "Iron        "print  "Cerium       "print "Barium        "print "Caesium       """[9::22];lambda:"Tin"[0];lambda:"Lead    "#print"Argon          "print"Radon          "print"Xenon          "print"Erbium         "print"Cobalt         "print"Copper         "print"Helium         "print"Indium         "print"Iodine         "print"Osmium         "print"Oxygen         "print"Radium         "print"Silver         "print"Sodium         "print"Sulfur         "print"Arsenic        "print"Bismuth        "print"Bohrium        "print"Bromine        "print"Cadmium        "print"Dubnium        "print"Fermium        "print"Gallium        "print"Hafnium        "print"Hassium        "print"Holmium        "print"Iridium        "print"Krypton        "print"Lithium        "print"Mercury        "print"Niobium        "print"Rhenium        "print"Rhodium        "print"Silicon        "print"Terbium        "print"Thulium        "print"Uranium        "print"Yttrium        "print"Actinium       "print"Antimony       "print"Astatine       "print"Chlorine       "print"Chromium       "print"Europium       "print"Fluorine       "print"Francium       "print"Hydrogen       "print"Lutetium       "print"Nitrogen       "print"Nobelium       "print"Platinum       "print"Polonium       "print"Rubidium       "print"Samarium       "print"Scandium       "print"Selenium       "print"Tantalum       "print"Thallium       "print"Titanium       "print"Tungsten       "print"Vanadium       "print"Nihonium       "print"Aluminium      "print"Americium      "print"Berkelium      "print"Beryllium      "print"Flerovium      "print"Germanium      "print"Lanthanum      "print"Magnesium      "print"Manganese      "print"Neodymium      "print"Neptunium      "print"Palladium      "print"Plutonium      "print"Potassium      "print"Ruthenium      "print"Strontium      "print"Tellurium      "print"Ytterbium      "print"Zirconium      "print"Moscovium      "print"Oganesson      "print"Dysprosium     "print"Gadolinium     "print"Lawrencium     "print"Meitnerium     "print"Molybdenum     "print"Phosphorus     "print"Promethium     "print"Seaborgium     "print"Technetium     "print"Tennessine     "print"Californium    "print"Copernicium    "print"Einsteinium    "print"Livermorium    "print"Mendelevium    "print"Roentgenium    "print"Darmstadtium   "print"Praseodymium   "print"Protactinium   "print"Rutherfordium  "

Ecco il venditore dopo il taglio e il taglio a cubetti:

lambda:"Gold"; print""  # <-- This is a function
"";print "Carbon     "
print   "Thorium     "
print   "Curium      "
print "Calcium       "
print "Nickel        "
print      "Zinc     "
print    "Neon       "
print "Boron         "
print   "Iron        "
print  "Cerium       "
print "Barium        "
print "Caesium       "
""[9::22];lambda:"Tin"  # <-- This is a function and the choke point
[0];lambda:"Lead    "#  # <-- This is a function
print"Argon          "
print"Radon          "
print"Xenon          "
print"Erbium         "
print"Cobalt         "
print"Copper         "
print"Helium         "
print"Indium         "
print"Iodine         "
print"Osmium         "
print"Oxygen         "
print"Radium         "
print"Silver         "
print"Sodium         "
print"Sulfur         "
print"Arsenic        "
print"Bismuth        "
print"Bohrium        "
print"Bromine        "
print"Cadmium        "
print"Dubnium        "
print"Fermium        "
print"Gallium        "
print"Hafnium        "
print"Hassium        "
print"Holmium        "
print"Iridium        "
print"Krypton        "
print"Lithium        "
print"Mercury        "
print"Niobium        "
print"Rhenium        "
print"Rhodium        "
print"Silicon        "
print"Terbium        "
print"Thulium        "
print"Uranium        "
print"Yttrium        "
print"Actinium       "
print"Antimony       "
print"Astatine       "
print"Chlorine       "
print"Chromium       "
print"Europium       "
print"Fluorine       "
print"Francium       "
print"Hydrogen       "
print"Lutetium       "
print"Nitrogen       "
print"Nobelium       "
print"Platinum       "
print"Polonium       "
print"Rubidium       "
print"Samarium       "
print"Scandium       "
print"Selenium       "
print"Tantalum       "
print"Thallium       "
print"Titanium       "
print"Tungsten       "
print"Vanadium       "
print"Nihonium       "
print"Aluminium      "
print"Americium      "
print"Berkelium      "
print"Beryllium      "
print"Flerovium      "
print"Germanium      "
print"Lanthanum      "
print"Magnesium      "
print"Manganese      "
print"Neodymium      "
print"Neptunium      "
print"Palladium      "
print"Plutonium      "
print"Potassium      "
print"Ruthenium      "
print"Strontium      "
print"Tellurium      "
print"Ytterbium      "
print"Zirconium      "
print"Moscovium      "
print"Oganesson      "
print"Dysprosium     "
print"Gadolinium     "
print"Lawrencium     "
print"Meitnerium     "
print"Molybdenum     "
print"Phosphorus     "
print"Promethium     "
print"Seaborgium     "
print"Technetium     "
print"Tennessine     "
print"Californium    "
print"Copernicium    "
print"Einsteinium    "
print"Livermorium    "
print"Mendelevium    "
print"Roentgenium    "
print"Darmstadtium   "
print"Praseodymium   "
print"Protactinium   "
print"Rutherfordium  "

inserisci qui la descrizione dell'immagine


Aggiornare

  • [16-09-08] Sublime ha aggiunto uno spazio extra quando si unisce a una riga che termina con un carattere di commento
  • [16-09-08] Ha reso ogni fetta lunga 22 caratteri e ha aggiunto gif

Sono abbastanza conosciuto in Python, come produce lambda:"Actinium";print""Actinium? Questo è forse particolare per Python 3?
Linus,

@Linus La parola chiave lambda crea una funzione anonima che non accetta parametri e restituisce Actinium. Il print ""non fa niente di utile dopo il venditore è stato smembrato.
NonlinearFruit
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.