Ile dostałeś śniegu?

12

Przepraszam za gadatliwość. Bawiliśmy się dobrze podczas pracy w naszym wewnętrznym golfie, ale wymagało to kilku e-maili do wyjaśnienia, więc mam nadzieję, że złapałem większość tego pierwszego razu.

PROBLEM

Biorąc pod uwagę „symulowaną” migawkę śniegu (jako ciąg, wartość standardowa lub parametr funkcji / metody), zgłoś 4 wartości: minimalną głębokość, maksymalną głębokość, średnią głębokość i czas trwania.

Oto sformatowany przykład ilustrujący dane wejściowe:

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

„*” To płatek śniegu, a „-” to ziemia. Wyobraź sobie wszystkie te „płatki śniegu” spadające na ziemię. To jest ostatnia „migawka”:

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

Musisz zgłosić:

  1. Minimalna głębokość - policz najkrótszy „stos” (1, w powyższym przykładzie)
  2. Maksymalna głębokość - policz najwyższy „stos” (4, w powyższym przykładzie)
  3. Średnia głębokość - średnia liczba wszystkich „stosów” (1,9, w powyższym przykładzie - zaokrąglenie do dziesiątych)
  4. Czas trwania - (każdy „upadek” = 1 sekunda) - czas od pierwszej migawki do ostatniej migawki (3 sekundy, w powyższym przykładzie)

Kolejny przykład w celach informacyjnych:

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

Ostateczna migawka:

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

WEJŚCIE

Początkowa „migawka” będzie miała 8 „wierszy”, 8 „kolumn” i będzie rozdzielana rurami (rury oddzielają rzędy). Na przykład (z wyłączeniem cytatów):

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

WYNIK

4 wartości rozdzielane potokami w jednym wierszu: 0 | 1 | .6 | 3 lub 0 | 5 | 1 | 1

Steve
źródło
Czy ziemia może mieć różne wysokości?
Nemo157
@ Nemo157 - to nie był nasz pierwotny problem, więc dla celów tutaj nie. To byłaby interesująca odmiana problemu.
Steve
Czy potrzebujesz zaokrąglić średnią?
Tytus

Odpowiedzi:

1

Perl, 128 znaków

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
źródło
6

Python, 153 znaki

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
źródło
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])

Dane wejściowe mają postać $s.

Historia:

  • 2011-02-10 01:53 (189) - Pierwsza próba.
  • 2011-02-10 02:03 (180) - Sformatuj ciąg znaków na ratunek. Jedyny minus: wyświetla dane liczbowe w formacie regionalnym, które nie są już ściśle zgodne ze specyfikacją zadania. Mimo to jest to problem wspólny również dla rozwiązania C #, więc myślę, że to w porządku.
Joey
źródło
0

Kilka innych języków wynika z naszego wewnętrznego golfa:

C #, 188 znaków (łatwo czytelnych)

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 znaków

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
źródło
0

PHP, 139 bajtów

<?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)]);

dla każdej kolumny policz nr. płatków śniegu i nie. spacji poniżej pierwszego płatka śniegu, a następnie obliczanie
przyjmuje ciąg znaków jako argument z wiersza poleceń

awarie i kroki w golfa

$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

dodać round(...,1)około array_sum($n)/8zaokrąglania (+9)

Tytus
źródło
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

W tym poście musiałem użyć uciekającego ciągu znaków, \nponieważ wklejanie i kopiowanie traci spacje. W interfejsie mogę wpisać to tak:

wprowadź opis zdjęcia tutaj

Mr.Wizard
źródło
0

JavaScript, 328 bajtów

Niezbyt krótki, ale to właśnie mam.

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)

Gra w golfa:

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
źródło