Сколько снега ты получил?

12

Мои извинения за многословность. Мы повеселились на работе в нашем внутреннем гольфе, но для разъяснения потребовалось несколько писем, поэтому я надеюсь, что большую часть этого я запечатлел в первый раз.

ПРОБЛЕМА

Учитывая «смоделированный» снимок снегопада (в виде строки, стандартного параметра или параметра для вашей функции / метода), укажите 4 значения: минимальная глубина, максимальная глубина, средняя глубина и продолжительность.

Вот отформатированный пример для иллюстрации ввода:

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

«*» - снежинка, а «-» - земля. Представьте, что все эти «снежинки» падают на землю. Это последний «снимок»:

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

Вам необходимо сообщить о:

  1. Минимальная глубина - считайте кратчайший «стопка» (1, в примере выше)
  2. Максимальная глубина - считайте самую высокую «кучу» (4, в примере выше)
  3. Средняя глубина - среднее количество всех «стопок» (1,9, в примере выше - округление до десятых долей)
  4. Длительность - (каждое «падение» = 1 секунда) - время от первого снимка до последнего снимка (3 секунды, в примере выше)

Еще один пример для справки:

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

Окончательный снимок:

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

ВХОД

Начальный «снимок» будет иметь 8 «рядов», 8 «столбцов» и разделяться на части (каналы разделяют строки). Например (исключая кавычки):

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

ВЫХОД

4 значения, разделенные по конвейеру в одной строке: 0 | 1 | .6 | 3 или 0 | 5 | 1 | 1

Стив
источник
Может ли земля иметь разную высоту?
Nemo157
@ Nemo157 - это не было в нашей первоначальной проблеме, поэтому для целей здесь нет. Это было бы интересным вариантом проблемы.
Стив
Требуется ли округление среднего?
Тит

Ответы:

1

Perl, 128 символов

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
источник
6

Python, 153 символа

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]))
Кит Рэндалл
источник
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])

Ввод поступает как $s.

История:

  • 2011-02-10 01:53 (189) - Первая попытка.
  • 2011-02-10 02:03 (180) - Формат строки для спасения. Единственный недостаток: выводит числа в региональном формате, более не строго соответствующие спецификации задачи. Тем не менее, это проблема, разделяемая решением C #, так что я думаю, что все в порядке.
детеныш
источник
0

Пара других языков является результатом нашего внутреннего игры в гольф:

C #, 188 символов (легко читается)

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

Рубин, 173 символа

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
Стив
источник
0

PHP, 139 байт

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

для каждого столбца считать номер снежинок и нет. пробелов ниже первой снежинки, а затем рассчитать
принимает строку в качестве аргумента из командной строки

поломка и игра в гольф

$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

добавить round(...,1)вокруг array_sum($n)/8для округления (+9)

Titus
источник
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

В этом посте мне пришлось прибегнуть к экранированной строковой форме, \nпоскольку вставка и копирование теряют пробелы. В Front End я могу ввести это так:

введите описание изображения здесь

Mr.Wizard
источник
0

JavaScript, 328 байт

Не особенно коротко, но это то, что у меня есть.

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)

Де-golfed:

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)
Дэвис
источник