Risolvi il debito globale, la via del golf del codice


32

I leader del mondo si sono incontrati e hanno finalmente ammesso che il modo migliore (e unico) per risolvere i problemi economici globali è quello di fare un bilancio di quanto si devono l'un l'altro e si ripagano semplicemente con enormi assegni. Ti hanno assunto (ironicamente, al tasso di contratto più basso possibile) per trovare il modo migliore per farlo.

Dopo molte discussioni e chiedendo a qualcuno di disegnare un semplice esempio, hanno escogitato le seguenti specifiche.

Ogni paese è rappresentato dal loro codice ISO 3166-1 alpha-2 : USper gli Stati Uniti, AUper l'Australia, JPper il Giappone, CNper la Cina e così via ...

  1. Un libro mastro viene redatto come una serie di voci di paese e gli importi dovuti a ciascun paese.
  2. L'ingresso di ciascun paese inizia con il loro ID di dominio un colon e quanto hanno in surplus / deficit (in miliardi di euro), seguito da un punto e virgola, quindi da un elenco separato da virgole dei paesi e quanto (in miliardi di Euro) devono.
  3. Se un paese non deve nulla a un altro paese, nessuna menzione di quel paese viene inserita dopo quel punto e virgola.
  4. I deficit sono indicati come numeri negativi, il surplus è indicato come numero positivo.
  5. I valori possono anche essere float.
  6. Il libro mastro deve essere preso da STDIN. La fine del libro mastro è indicata da un ritorno a capo su una riga vuota. Il conteggio deve essere consegnato a STDOUT.

Un esempio di un libro mastro:

Input:
AU:8;US:10,CN:15,JP:3
US:14;AU:12,CN:27,JP:14
CN:12;AU:8,US:17,JP:4
JP:10;AU:6,US:7,CN:10

Il sistema quindi determina l'importo che ogni paese deve e deve e determina il suo avanzo / disavanzo, ad esempio per AU:

AU = 8 (avanzo corrente) -10 (verso gli USA) -15 (verso CN) -3 (verso JP) +12 (dagli USA) +8 (da CN) +6 (da JP) = 6

Quando tutto il calcolo è fatto, deve essere mostrato un conteggio:

Output:
AU:6
US:-5
CN:35
JP:8

Il tuo compito è quello di creare questo sistema, in grado di prendere un numero qualsiasi di voci di contabilità per qualsiasi numero di paesi e in grado di determinare quanto ogni paese ha deficit / surplus quando tutto viene pagato.

Il test finale consiste nell'utilizzare il codice per risolvere il debito dovuto tra i seguenti paesi nel caso di prova riportato di seguito. Queste cifre sono state tratte da BBC News nel giugno 2011. ( http://www.bbc.com/news/business-15748696 )

Ai fini dell'esercizio, ho usato il loro rispettivo PIL come surplus attuale ... Tieni presente che si tratta strettamente di un esercizio di garanzia della qualità del codice ... non si parlerà qui della risoluzione economica globale in questa domanda ... Se vuoi parlare di economia sono sicuro che c'è un altro sottodominio in SE che lo gestisce ...

US:10800;FR:440.2,ES:170.5,JP:835.2,DE:414.5,UK:834.5
FR:1800;IT:37.6,JP:79.8,DE:123.5,UK:227,US:202.1
ES:700;PT:19.7,IT:22.3,JP:20,DE:131.7,UK:74.9,US:49.6,FR:112
PT:200;IT:2.9,DE:26.6,UK:18.9,US:3.9,FR:19.1,ES:65.7
IT:1200;JP:32.8,DE:120,UK:54.7,US:34.8,FR:309,ES:29.5
IE:200;JP:15.4,DE:82,UK:104.5,US:39.8,FR:23.8
GR:200;DE:15.9,UK:9.4,US:6.2,FR:41.4,PT:7.5,IT:2.8
JP:4100;DE:42.5,UK:101.8,US:244.8,FR:107.7
DE:2400;UK:141.1,US:174.4,FR:205.8,IT:202.7,JP:108.3
UK:1700;US:578.6,FR:209.9,ES:316.6,IE:113.5,JP:122.7,DE:379.3

Ora, sii il salvatore economico del mondo!

Regole:

  1. Vince il codice più corto ... dopo tutto questo è code-golf ...
  2. Fornisci l'output del caso di test principale con la risposta del codice ...

1
Nel "test finale", non dovrebbe esserci un punto e virgola dopo JP:4100?
Mathieu Rodic

9
Non posso fare a meno di chiedermi se questo è un modo molto intelligente di completare un compito per te. Se è così, te lo meriti.
Mkingston,

2
Sì, se lo facessi in numeri reali noteresti una sorprendente contraddizione. La somma di tutte le eccedenze e i deficit sarà negativa.
Cruncher,

3
In realtà, non è un compito sotto mentite spoglie ... È stato ispirato dal mio torneo settimanale di poker con i miei amici ... Sto cercando di capire un modo più veloce di calcolare le vincite per ogni giocatore;)
WallyWest

1
@WallyWest LOL;) a proposito, mi scuso per i commenti OT, ma è una questione di cui sono abbastanza appassionato. Ora torniamo ad un po 'di codice divertente e dimentichiamo i guai del mondo ...
Tobia,

Risposte:


11

K, 66

{(((!)."SF"$+":"\:'*+a)-+/'d)+/d:"F"$(!).'"S:,"0:/:last'a:";"\:'x}

.

k)input:0:`:ledg.txt
k){(((!)."SF"$+":"\:'*+a)-+/'d)+/d:"F"$(!).'"S:,"0:/:last'a:";"\:'x} input
US| 9439.3
FR| 2598.9
ES| 852.1
PT| 90.1
IT| 887.5
IE| 48
GR| 116.8
JP| 4817.4
DE| 2903.7
UK| 1546.2

Incredibilmente colpito da questo ... qualche possibilità che tu possa fornire un collegamento al paradigma di programmazione K?
WallyWest,

@WallyWest code.kx.com fornisce molte informazioni su q, che è lo zucchero sintattico che si trova sopra k. q, grazie a k, è quello che troverai nei sistemi di produzione ma per il golf k ha il vantaggio. Dai un'occhiata anche a Kona ( github.com/kevinlawler/kona ) che è un'implementazione open source di una versione precedente di k
tmartin

10

Perl, 139 137 134 119 112

Ecco un altro pezzo di codice funzionante ... Lo documenterò più avanti.

Codice golf

Con dizionario (112):

for(<>){~/:(.+);/g;$d{$c=$`}+=$1;$l=$';$d{$1}+=$2,$d{$c}-=$2while$l=~/(..):([^,]+)/g}print"$_:$d{$_}
"for keys%d

Senza dizionario (137):

for($T=$t.=$_ for<>;$t=~/(..:)(.+);(.+)/g;print"$c$s\n"){$c=$1;$l=$3;$s=$2;$s-=$&while$l=~/[\d.]+/g;$s+=$1while$T=~/$c([\d.]+)(?!;|\d)/g}

Produzione

US:9439.3
FR:2598.9
ES:852.1
PT:90.1
IT:887.5
IE:48
GR:116.8
JP:4817.4
DE:2903.7
UK:1546.2

Guardalo in azione!

http://ideone.com/4iwyEP


4
La definizione di "breve" dovrebbe essere valutata in base alla quantità di token, non ai caratteri. Leggibilità 4 punti vita!
Domi,

10
@Domi - sei nuovo qui, non è vero ;-)
jimbobmcgee,

4
@jimbobmcgee: Ho anche la sensazione che questo sito non sia molto leggibile ...
Mathieu Rodic,

4

Python, 211 185 183

import sys,re;t,R,F=sys.stdin.read(),re.findall,float;S=lambda e,s:sum(map(F,R(e,s)))
for m in R('(..:)(.+);(.+)',t):print m[0]+`F(m[1])+S(m[0]+'([\d.]+)(?!;|\d)',t)-S('[\d.]+',m[2])`

Uscita con caso di test importante:

US:9439.300000000001
FR:2598.9
ES:852.0999999999999
PT:90.09999999999997
IT:887.5
IE:48.0
GR:116.8
JP:4817.4
DE:2903.7
UK:1546.2000000000003

(testalo qui: http://ideone.com/CjWG7v )


4

C - 257 253 se nessun CR alla fine della linea

Dipende dalla dimensione di (breve) == 2.

Nessun controllo per overflow del buffer.

#define C(c) x[*(short*)c]
main(i){double x[23131]={0},d;char*q,b[99],*(*s)()=strtok;for(;gets(b);)for(s(b,":"),C(b)+=atof(s(0,";"));q=s(0,":");C(b)-=d=(atof(s(0,","))),C(q)+=d);for(i=b[2]=0;i<23131;memcpy(b,&i,2),x[i]?printf("%s:%f\n",b,x[i++]):++i);}

Produzione:

DE:2903.700000  
IE:48.000000    
UK:1546.200000  
JP:4817.400000  
FR:2598.900000  
GR:116.800000   
ES:852.100000   
US:9439.300000  
IT:887.500000   
PT:90.100000   

Meno golf:

#define C(c) x[*(short*)c]

main(i)
{
    double x[23131]={0}, d;
    char *q, b[99], *(*s)()=strtok;
    for(;gets(b);) 
        for(s(b, ":"),C(b)+=atof(s(0, ";")); 
            q=s(0, ":"); 
            C(b)-=d=(atof(s(0, ","))), C(q)+=d) ;

    for(i=b[2]=0; 
        i<23131; 
        memcpy(b, &i, 2), x[i]?printf("%s:%f\n", b, x[i++]):++i) ;
}

3

PHP - 338, 280

Dovrebbe funzionare con qualsiasi versione di PHP 5.

Golfato :

while(preg_match("#(..):(.+);(.*)#",fgets(STDIN),$m)){$l[$m[1]][0]=(float)$m[2];foreach(explode(",",$m[3])as$x){$_=explode(":",$x);$l[$m[1]][1][$_[0]]=(float)$_[1];}}foreach($l as$c=>$d)foreach($d[1]as$_=>$o){$l[$_][0]+=$o;$l[$c][0]-=$o;}foreach($l as$c=>$d)echo$c,":",$d[0],"\n";

Non golfato :

<?php

while( preg_match( "#(..):(\d+);(.*)#", fgets( STDIN ), $m ) )
{
    $l[$m[1]][0] = (float)$m[2];

    foreach( explode( ",", $m[3] ) as $x )
    {
        $_ = explode( ":", $x );
        $l[$m[1]][1][$_[0]] = (float)$_[1];
    }
}

foreach( $l as $c => $d )
    foreach( $d[1] as $_ => $o )
    {
        $l[$_][0] += $o;
        $l[$c][0] -= $o;
    }

foreach( $l as $c => $d )
    echo $c, ":", $d[0], "\n";

Uscita :

US:9439.3
FR:2598.9
ES:852.1
PT:90.1
IT:887.5
IE:48
GR:116.8
JP:4817.4
DE:2903.7
UK:1546.2

Non sarebbe più corto se lo usassi preg_match_all()e lo facessi una volta sola?
Damir Kasipovic,

3

perl (184 caratteri)

Codice

%c,%d,%e=();while(<>){$_=~/(..):(.+);(.*)/;$n=$1;$c{$1}=$2;for $i(split /,/,$3){$i=~/(..):(.+)/;$d{$1}+=$2;$e{$n}+=$2;}}for $i(keys %c){$c{$i}+=$d{$i}-$e{$i};print $i.":".$c{$i}."\n";}

Produzione

UK:1546.2
DE:2903.7
IT:887.5
FR:2598.9
PT:90.1
US:9439.3
JP:4817.4
ES:852.1
IE:48
GR:116.8

3

Perl - 116 114 112

for(<>){($n,$m,@l)=split/[:;,]/;$h{$n}+=$m;$h{$n}-=$p,$h{$o}+=$p while($o,$p,@l)=@l}print"$_:$h{$_}\n"for keys%h

Produzione:

GR:116.8
UK:1546.2
DE:2903.7
IE:48
IT:887.5
US:9439.3
PT:90.1
ES:852.1
FR:2598.9
JP:4817.4

Ungolfed:

for(<>) {
    ($n, $m, @l)=split(/[:;,]/);
    $h{$n}+=$m;

    $h{$n}-=$p, $h{$o}+=$p while ($o,$p,@l)=@l
}
print "$_:$h{$_}\n" for keys%h

Bello! Mi piace il tuo approccio :)
Mathieu Rodic,

3

C ++ - 1254

#include<iostream>
#include<cstring>
#include<vector>
#include<sstream>
#include<cstdlib>
using namespace std;int main(){vector<string>input,countries,output;vector<double>results;string last_val;int j,k,i=0;cout<<"Input\n";do{getline(cin,last_val);if(last_val!=""){input.push_back(last_val);countries.push_back(last_val.substr(0,2));}}while(last_val!="");for(j=0;j<countries.size();j++){results.push_back(0);for(k=0;k<input.size();k++)input[k].substr(0, 2)==countries[j]?results[j]+=atof(input[k].substr((input[k].find(countries[j])+3),(input[k].find(',',input[k].find(countries[j]))-input[k].find(countries[j]))).c_str()):results[j]+=atof(input[k].substr((input[k].find(countries[j],3)+3),(input[k].find(',',input[k].find(countries[j]))-input[k].find(countries[j]))).c_str());}for(j=0;j<input.size();j++){for(k=0;k<countries.size();k++){if(input[j].substr(0,2)!=countries[k]){results[j]-=atof(input[j].substr((input[j].find(countries[k])+ 3),(input[j].find(',',input[k].find(countries[k]))-input[j].find(countries[j]))).c_str());}}}for(i=0;i<countries.size();i++){stringstream strstream;strstream<<countries[i]<<":"<<results[i];output.push_back(strstream.str().c_str());}cout<<"Output:\n";for(i=0;i<output.size();i++){cout<<output[i]<<'\n';}return 0;}

Mi rendo conto che il codice è molto lungo, ma mi sono divertito molto. Questa è la mia prima volta che gioca a golf con il codice e sono nuovo in C ++, quindi i suggerimenti per migliorare il mio codice sono molto apprezzati.

Risultati della sfida finale

Output:
US:9439.3
FR:2598.9
ES:852.1
PT:90.1
IT:887.5
IE:48
GR:116.8
JP:4817.4
DE:2903.7
UK:1546.2

Codice Ungolfed

#include<iostream>
#include<cstring>
#include<vector>
#include<sstream>
#include<cstdlib>

using namespace std;

int main() {
  vector<string> input, countries, output;
  vector<double> results;
  string last_val;
  int i, j, k;

  cout << "Input\n";
  do {
    getline(cin, last_val);
    if(last_val != "") {
      input.push_back(last_val);
      countries.push_back(last_val.substr(0, 2));
    }
  } while(last_val != "");

  for(j = 0; j < countries.size(); j++) {
    results.push_back(0);
    for(k = 0; k < input.size(); k++) {
      if(input[k].substr(0, 2) == countries[j]) {
        results[j] += atof(input[k].substr((input[k].find(countries[j]) + 3),
                             (input[k].find(',', input[k].find(countries[j])) -
                              input[k].find(countries[j]))).c_str());
      } else {
        results[j] += atof(input[k].substr((input[k].find(countries[j], 3) + 3),
                             (input[k].find(',', input[k].find(countries[j])) -
                              input[k].find(countries[j]))).c_str());
      }
    }
  }

  for(j = 0; j < input.size(); j++) {
    for(k = 0; k < countries.size(); k++) {
      if(input[j].substr(0, 2) != countries[k]) {
        results[j] -= atof(input[j].substr((input[j].find(countries[k]) + 3),
                             (input[j].find(',', input[k].find(countries[k])) -
                              input[j].find(countries[j]))).c_str());
      }
    }
  }

  for(i = 0; i < countries.size(); i++) {
    stringstream strstream;
    strstream << countries[i] << ":" << results[i];
    output.push_back(strstream.str().c_str());
  }

  cout << "Output:\n";
  for(i = 0; i < output.size(); i++) {
    cout << output[i] << '\n';
  }

  return 0;
}

2
Ciao, è bello vedere un esempio in C ++. È possibile ridurre il numero di caratteri utilizzando identificatori a una lettera anziché nomi descrittivi, ovvero utilizzare i per l' input , c per i paesi e così via.
ahy1

Concordato con @ ahy1 qui ... Se riduci le variabili a 1 lettera puoi tagliare un bel po 'di questo ... Potresti anche trovare questo di interesse per le future sfide del golf: codegolf.stackexchange.com/questions/132/tips -per-golf-in-c
WallyWest

Oh, e non avrai nemmeno bisogno cout << "Output:\n";... Questo è un risparmio di 20 byte lì ...
WallyWest

3

AWK - 138 120

{l=split($0,h,"[:,;]");t[h[1]]+=h[2];for(i=3;i<l;i+=2){t[h[1]]-=h[i+1];t[h[i]]+=h[i+1]}}END{for(v in t){print v":"t[v]}}

E i risultati

$ cat data.withoutInputHeadline |awk -f codegolf.awk
IT:887.5
UK:1546.2
DE:2903.7
PT:90.1
ES:852.1
FR:2598.9
GR:116.8
Input:0
JP:4817.4
IE:48
US:9439.3

Ungolfed

{
    l=split($0,h,"[:,;]");
    t[h[1]]+=h[2];
    for(i=3;i<l;i+=2){
        t[h[1]]-=h[i+1]
        t[h[i]]+=h[i+1]
    }
}
END{
    for(v in t){
        print v":"t[v]
    }
}

(testalo qui: http://ideone.com/pxqc07 )


Perché persino inserire quelle intestazioni?
Salverai

@WallyWest: Ok, quindi non l'ho capito, perché sono visualizzati nel tuo primo esempio di Input e Output, ad esempio: (..) deve essere mostrato un conteggio: Output: (..) Non preoccuparti, rimuovo il mio primo esempio in questo momento.
Doomsday

2

Rubino - 225

Prima prova in una sfida come questa, sicuramente potrebbe essere molto meglio ...

R=Hash.new(0)
def pd(s,o=nil);s.split(':').tap{|c,a|R[c]+=a.to_f;o&&R[o]-=a.to_f};end
STDIN.read.split("\n").each{|l|c,d=l.split(';');pd(c);d.split(',').each{|s|pd(s,c.split(':')[0])}}
puts R.map{|k,v|"#{k}: #{v}"}.join("\n")

E i risultati

$ cat data|ruby codegolf.rb
US: 9439.299999999997
FR: 2598.8999999999996
ES: 852.1
JP: 4817.4
DE: 2903.7
UK: 1546.2000000000003
IT: 887.5
PT: 90.09999999999998
IE: 48.0
GR: 116.8

2

JS, 254 240 245

z='replace';r={};p=eval(('[{'+prompt()+'}]')[z](/\n/g,'},{')[z](/;/g,','));for(i in p){l=p[i];c=0;for(k in l){if(!c){c=k;r[c]=0;}else{r[c]-=l[k];}};for(j in p){w=p[j][c];if(w!=null)r[c]+=w}};alert(JSON.stringify(r)[z](/"|{|}/g,'')[z](/,/g,'\n'))

Beh ... so che è piuttosto lungo ma questo è il mio secondo codice golf.

I suggerimenti sono benvenuti!

A proposito, Javascript interessante conserva l'ordine degli elementi negli hashmap, quindi, anche se p contiene una matrice di dizionari, posso iterare ogni dizionario come una matrice e sono sicuro che il primo elemento di un dict sia il primo inserito. (il nome del paese riferito alla riga corrente)

Ungolfed:

z='replace';
r={};
p=eval(('[{'+prompt()+'}]')[z](/\n/g,'},{')[z](/;/g,',')); // make the string JSONable and then evaluate it in a structure
for(i in p){ 
    l=p[i];
    c=0;
    for(k in l){
            if(!c){ // if c is not still defined, this is the country we are parsing.
                    c=k;
                    r[c]=0;
            }
            else r[c]-=l[k];
    }; 
    for(j in p){
            w=p[j][c];
            if(!w)  r[c]+=w
    }
};
alert(JSON.stringify(r)[z](/"|{|}/g,'')[z](/,/g,'\n')) # Stringify the structure, makes it new-line separated.

Nota: l'ingresso è un prompt()che dovrebbe essere una riga singola. Ma se copi / incolli un testo su più righe (come l'input proposto) in una prompt()finestra, JSleggi tutto.

Produzione:

US:9439.3
FR:2598.9
ES:852.1
PT:90.09999999999998
IT:887.5
IE:48
GR:116.8
JP:4817.4
DE:2903.7000000000003
UK:1546.2

1
Usa la parola "sostituisci" quattro volte nel tuo codice. Che ne dici di accorciarlo in questo modo z='replace';r={};p=eval(('[{'+prompt()+'}]')[z](/\n/g,'},{')[z](/;/g,','));for(i in p){l=p[i];c=0;for(k in l){if(!c){c=k;r[c]=0;}else{r[c]-=l[k];}};for(j in p){w=p[j][c];if(w!=null)r[c]+=w}};alert(JSON.stringify(r)[z](/"|{|}/g,'')[z](/,/g,'\n')):?
user2428118

Questo mi ha salvato 7 * 4- (3 * 4 + 11) personaggi! (Ho anche messo (w!=null)come(!w)
Antonio Ragagnin il

@AntonioRagagnin Potresti mostrare la tua uscita per favore?
WallyWest,

Grazie per il tuo messaggio @WallyWest. Risulta !wnon è stata una buona idea controllare w!=nulle lo script non funzionava più: p. Ora lo aggiornerò con i risultati
Antonio Ragagnin,

Prova a usare: z="replace";r={};p=eval(("[{"+prompt()+"}]")[z](/\n/g,"},{")[z](/;/g,","));for(i in p){l=p[i];c=0;for(k in l)c?r[c]-=l[k]:(c=k,r[c]=0);for(j in p)w=p[j][c],null!=w&&(r[c]+=w)}alert(JSON.stringify(r)[z](/"|{|}/g,"")[z](/,/g,"\n"))per 229 byte ... Quello che ho fatto qui è ridurre la if(!c)sequenza a un singolo operatore ternario, e l'ho anche incorporato nel suo forciclo genitore ... Ho anche fatto qualcosa di simile con l'altro forciclo ... gli operatori virgola possono lavorare meravigliosamente per unire più istruzioni in un ciclo ...
WallyWest

2

JavaScript (ES6) 175 , 166 , 161 , 156 , 153 147

golfed

R={};prompt().split(/\s/).map(l=>{a=l.split(/[;,:]/);c=b=a[0];a.map(v=>b=!+v?v:(R[b]=(R[b]||0)+ +v c==b?b:R[c]-=+v))});for(x in R)alert(x+':'+R[x])

Ungolfed

R = {};
prompt().split(/\s/).map(l => {
    a = l.split(/[;,:]/);       // Split them all!! 
                                // Now in a we have big array with Country/Value items
    c = b = a[0];               // c - is first country, b - current country
    a.map(v =>                
         b = !+v ? v                 // If v is country (not a number), simply update b to it's value          
                 : (R[b] = (R[b] ||0) + +v   // Safely Add value to current country
                   c == b ? c : R[c] -= +v)  // If current country is not first one, remove debth 
    )
});
for (x in R) alert(x + ':' + R[x])

Produzione

US:9439.299999999997
FR:2598.8999999999996
ES:852.1
JP:4817.4
DE:2903.7
UK:1546.2000000000003
IT:887.5
PT:90.09999999999998
IE:48
GR:116.8

Non sono sicuro che la variante non golfata funzionerà correttamente perché nella variante
golfata

puoi per favore mostrare il tuo output?
WallyWest,

1
Sostituito R[b] ? R[b] += +v : R[b] = +vaR[b]=R[b]||0+ +v
tt.Kilew

1
Indice rimosso i=0;i++%2==0?b=vab=isNaN(+v)?v:
tt.Kilew

1
isNaN(+v)->!+v
tt.Kilew

1

Groovy 315

def f(i){t=[:];i.eachLine(){l=it.split(/;|,/);s=l[0].split(/:/);if(!z(s[0]))t.put(s[0],0);t.put(s[0],x(z(s[0]))+x(s[1]));(1..<l.size()).each(){n=l[it].split(/:/);t.put(s[0],x(z(s[0]))-x(n[1]));if(!z(n[0]))t.put(n[0],0);t.put(n[0],x(z(n[0]))+x(n[1]))}};t.each(){println it}};def x(j){j.toDouble()};def z(j){t.get(j)}

Output:
US=9439.299999999997
FR=2598.8999999999996
ES=852.1
JP=4817.4
DE=2903.7
UK=1546.2000000000003
IT=887.5
PT=90.09999999999998
IE=48.0
GR=116.8

Ungolfed:

input = """US:10800;FR:440.2,ES:170.5,JP:835.2,DE:414.5,UK:834.5
FR:1800;IT:37.6,JP:79.8,DE:123.5,UK:227,US:202.1
ES:700;PT:19.7,IT:22.3,JP:20,DE:131.7,UK:74.9,US:49.6,FR:112
PT:200;IT:2.9,DE:26.6,UK:18.9,US:3.9,FR:19.1,ES:65.7
IT:1200;JP:32.8,DE:120,UK:54.7,US:34.8,FR:309,ES:29.5
IE:200;JP:15.4,DE:82,UK:104.5,US:39.8,FR:23.8
GR:200;DE:15.9,UK:9.4,US:6.2,FR:41.4,PT:7.5,IT:2.8
JP:4100;DE:42.5,UK:101.8,US:244.8,FR:107.7
DE:2400;UK:141.1,US:174.4,FR:205.8,IT:202.7,JP:108.3
UK:1700;US:578.6,FR:209.9,ES:316.6,IE:113.5,JP:122.7,DE:379.3"""

ungolfed(input)

def ungolfed(i){
    def tallyMap = [:]
    i.eachLine(){ 
        def lineList = it.split(/;|,/)
        def target = lineList[0].split(/:/)

        if(!tallyMap.get(target[0])){tallyMap.put(target[0],0)}
        tallyMap.put(target[0],tallyMap.get(target[0]).toDouble() + target[1].toDouble())
        (1..lineList.size()-1).each(){ e ->
            def nextTarget = lineList[e].split(/:/)
            //subtract the debt
            tallyMap.put(target[0], (tallyMap.get(target[0]).toDouble() - nextTarget[1].toDouble()))
            //add the debt
            if(!tallyMap.get(nextTarget[0])){ tallyMap.put(nextTarget[0], 0) }
            tallyMap.put(nextTarget[0], (tallyMap.get(nextTarget[0]).toDouble() + nextTarget[1].toDouble()))  
        }
    }
    tallyMap.each(){
        println it
    }
}

Ti capita di avere un link a dove posso trovare maggiori informazioni su Groovy?
WallyWest,

@WallyWest: ho questo libro e ho imparato tonnellate da esso. Sento che questa è una di quelle lingue in cui è bene avere un riferimento sullo scaffale. link , anche tonnellate di informazioni qui: link
md_rasler

1

PHP, 333

$a='';while(($l=trim(fgets(STDIN)))!='')$a.=$l.'\n';$a=rtrim($a,'\n');$p=explode('\n',$a);foreach($p as $q){preg_match('/^([A-Z]+)/',$q,$b);preg_match_all('/'.$b[0].':(\d+(?:\.\d+)?)/',$a,$c);$e=ltrim(strstr($q,';'),';');preg_match_all('/([A-Z]+)\:(\d+(?:\.\d+)?)/',$e,$d);echo $b[0].':'.(array_sum($c[1])-array_sum($d[2])).PHP_EOL;}

Versione non golfata:

$a='';
while(($l=trim(fgets(STDIN)))!='')
    $a .= $l.'\n';
$a = rtrim($a,'\n');
$p = explode('\n',$a);
foreach($p as $q){
    preg_match('/^([A-Z]+)/',$q,$b);
    preg_match_all('/'.$b[0].':(\d+(?:\.\d+)?)/',$a,$c);
    $e = ltrim(strstr($q,';'),';');
    preg_match_all('/([A-Z]+)\:(\d+(?:\.\d+)?)/', $e, $d);
    echo $b[0].':'.(array_sum($c[1])-array_sum($d[2])).PHP_EOL;
}
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.