Wie viel Schnee hast du bekommen?

12

Ich entschuldige mich für die Worthaftigkeit. Wir hatten Spaß damit bei der Arbeit in unserem internen Golfspiel, aber es waren einige E-Mails zur Klärung erforderlich, und ich hoffe, dass ich das meiste davon beim ersten Mal erfasst habe.

PROBLEM

Geben Sie bei einem „simulierten“ Schneefall-Schnappschuss (als Zeichenfolge, Standardwert oder Parameter für Ihre Funktion / Methode) 4 Werte an: Minimaltiefe, Maximaltiefe, durchschnittliche Tiefe und Dauer.

Hier ist ein formatiertes Beispiel, um die Eingabe zu veranschaulichen:

* * **     
** * ***    
** *  *    
*          
--------

Das '*' ist eine Schneeflocke und das '-' ist der Boden. Stellen Sie sich all diese „Schneeflocken“ vor, die auf den Boden fallen. Dies ist der letzte "Schnappschuss":

*      
*          
** * **    
********    
--------

Sie müssen berichten über:

  1. Minimale Tiefe - Zähle den kürzesten „Stapel“ (1, im obigen Beispiel)
  2. Maximale Tiefe - Zähle den höchsten "Stapel" (4, im obigen Beispiel)
  3. Durchschnittliche Tiefe - durchschnittliche Anzahl aller „Pfähle“ (1,9, im obigen Beispiel - auf Zehntel gerundet)
  4. Dauer - (jeder "Fall" = 1 Sekunde) - Zeit vom ersten bis zum letzten Schnappschuss (3 Sekunden, im obigen Beispiel)

Ein weiteres Beispiel als Referenz:

     * 
   *   *
      *
*      
--------

Letzter Schnappschuss:

*  * ***
--------

EINGANG

Der Start-Snapshot hat 8 Zeilen und 8 Spalten und ist durch Pipes getrennt (die Pipes trennen die Zeilen). Zum Beispiel (ohne Anführungszeichen):

“        |        |        |        |     *  |   *   *|      * |*       |--------” 

AUSGABE

Die 4 Werte werden in einer einzelnen Zeile durch Pipe getrennt: 0 | 1 | .6 | 3 oder 0 | 5 | 1 | 1

Steve
quelle
Kann der Boden unterschiedliche Höhen haben?
Nemo157
@ Nemo157 - das war nicht in unserem ursprünglichen Problem, also für die Zwecke hier, nein. Das wäre eine interessante Variante des Problems.
Steve
Benötigen Sie eine Rundung des Durchschnitts?
Titus

Antworten:

1

Perl, 128 Zeichen

map{$d++;s/\*/$d{$-[0]}++;$t&&$t<$d or$t=$d/ge}split'\|',<>;map{$A+=$_/8}@m=sort values%d;printf"$m[0]|$m[-1]|%.1f|%d\n",$A,8-$t
Ninjalj
quelle
6

Python, 153 Zeichen

s=raw_input()
R=range(8)
C=[s[i::9].count('*')for i in R]
print"%d|%d|%.1f|%d"%(min(C),max(C),sum(C)/8.,max(8-s[i::9].find('*')-C[i]for i in R if C[i]))
Keith Randall
quelle
1

Windows PowerShell, 180 189

$a=(0..7|%{$x=$_;-join(0..7|%{$s[$_*9+$x]})})
$b=$a-replace' '|%{$_.length}|sort
"{0}|{1}|{2:.0}|{3}"-f($b[-1..0]+(($b-join'+'|iex)/8),($a|%{($_-replace'^ +|\*').length}|sort)[-1])

Eingang kommt als $s.

Geschichte:

  • 2011-02-10 01:53 (189) - Erster Versuch.
  • 2011-02-10 02:03 (180) - Formatieren Sie die Zeichenfolge zur Rettung. Einziger Nachteil: Es werden Zahlen im Regionalformat ausgegeben, die nicht mehr der Aufgabenspezifikation entsprechen. Trotzdem ist das ein Problem, das auch von der C # -Lösung geteilt wird, also denke ich, dass das in Ordnung ist.
Joey
quelle
0

Ein paar andere Sprachen ergeben sich aus unserem internen Golfspiel:

C #, 188 Zeichen (leicht lesbar)

int a = 0, b = 8, c = 0, d = 0, f, i, j, x;    
for (i = 0; i < 8; i++)    
{    
      f = x = 0;    
      for (j = 0; j < 8; )
            if (s[i + j++ * 9] == '*')    
            {    
                  x = x > 0 ? x : 9 - j;    
                  f++;    
            }         

      d += f;    
      a = f > a ? f : a;    
      b = f < b ? f : b;    
      c = x - f > c ? x - f : c;    
}

Console.Write("{0}|{1}|{2:.0}|{3}", b, a, d / 8f, c);

Ruby, 173 Zeichen

s=gets;n=8;a=o=l=0;8.times{|i|f=x=0;8.times{|j|if(s[i+j*9].chr=='*'):x=8-j if x==0;f+=1;end}
o+=f;a=f if f>a;n=f if f<n;l=x-f if x-f>l}
printf "%d|%d|%.1f|%d",n,a,o.to_f/8,l
Steve
quelle
0

PHP, 139 Bytes

<?for(;$y<8;$y++)for($x=0;++$n[$x],$x<8;$x++)'!'>$argv[1][$y*9+$x]&&--$n[$x]?$b[$x]++:0;print_r([min($n),max($n),array_sum($n)/8,max($b)]);

Zählen Sie für jede Spalte Nr. von Schneeflocken und nein. von Leerzeichen unter der ersten Schneeflocke, dann
nimmt berechne String als Argument von der Kommandozeile

Pannen- und Golfschritte

$i=$argv[1];
for(;$y<8;$y++)         # $y=row
{
    for($x=0;$x<8;$x++) # $x=column
    {
        // loop body: 32+26=58 bytes
        if('*'==$i[$p=$y*9+$x])$n[$x]++;# if snowflake: increase snowflakes count
        elseif($n[$x]+=0)$b[$x]++;      # elseif has snowflakes: increase blanks count
                                        # +=0: min needs a value in every column

        // -> golf if/elseif to ternaries, 16+9+25+1 = 51 (-7)
#       '*'==$i[$y*9+$x]
#           ? $n[$x]++
#           : (($n[$x]+=0)?$b[$x]++:0)
#       ;

        // golfing on the ternary, 15+23+9+1 = 48 (-3)
#       '!'>$i[$y*9+$x]                 # -1: char<'!' <=> char==' '
#           ? ($n[$x]+=0)?$b[$x]++:0    # -2: inverted condition -> eliminated parens
#           : $n[$x]++
#       ; # 15+23+9+1-2=46

        // increase snowflakes count in any case (initialization)
        // (needs curlies; elminate them by moving increase to the for condition)
        // decrease snowflakes count for blank
#       ++$n[$x];if('!'>$i[$y*9+$x]&&--$n[$x])$b[$x]++; # if: 47
#       ++$n[$x];'!'>$i[$y*9+$x]&&--$n[$x]?$b[$x]++:0;  # ternary: 46
    }
}
print_r([min($n),max($n),array_sum($n)/8,max($b)]); # calculate and print results

füge round(...,1)herum array_sum($n)/8zum Runden (+9)

Titus
quelle
0

Mathematica , ~ 115

"        \n        \n* * **  \n        \n** * ***\n** *  * \n*       \n--------"

Most/@ToCharacterCode@%~Partition~9/10-16/5
Min@#|Max@#|Mean@#~Round~.1|Position[#,1][[{-1,1},1]].{1,-1}-1&@Total@%
1 | 4 | 1.9 | 4

In diesem Beitrag musste ich auf die maskierte Zeichenfolge zurückgreifen, \nda beim Einfügen und Kopieren Leerzeichen verloren gingen. Im Frontend kann ich es so eingeben:

Bildbeschreibung hier eingeben

Mr.Wizard
quelle
0

JavaScript, 328 Bytes

Nicht besonders kurz, aber es ist das, was ich habe.

var input = "        |        |        |* * **  |        |** * ***|** *  * |*       |--------";

(s=>{var l=s.split("|"),a=[0,0,0,0,0,0,0,0],o=[8,0,0,0],b;for(i=0;i<l.length;i++){if(!b&&l[i]!="        ")o[3]=7-i,b=1;for(j=0;j<l[i].length;j++){a[j]+=l[i][j]=="*"?1:0}}for(i=0;i<a.length;i++){if(a[i]<o[0])o[0]=a[i];if(a[i]>o[1])o[1]=a[i];o[2]+=a[i];}console.log(o[0]+"|"+o[1]+"|"+(o[2]/a.length).toFixed(1)+"|"+o[3]);})(input)

Entgolft:

var input = "        |        |        |        |     *  |   *   *|      * |*       |--------";

(s=>{
  var splits = s.split("|");
  var arr = [0,0,0,0,0,0,0,0];
  var b;
  var o=[8,0,0,0];
  for (var i = 0; i < splits.length; i++) {
    if (!b&&splits[i]!="        ") {
      o[3] = 7-i;b=1;
    }
    for (var j = 0; j < splits[i].length; j++) {
      arr[j]+=splits[i][j]=="*"?1:0;
    }
  }
  for (var i = 0; i < arr.length; i++) {
    if (arr[i]<o[0]) {
      o[0]=arr[i];
    }
    if (arr[i]>o[1]) {
      o[1]=arr[i];
    }
    o[2]+=arr[i];
  }
  console.log(o[0]+"|"+o[1]+"|"+(o[2]/arr.length).toFixed(1)+"|"+o[3]);
})(input)
Davis
quelle