Previsão do tempo

13

Escreva o programa mais curto para prever o tempo para os próximos 7 dias

A entrada (de stdin) é o dia da semana e a estação

A saída (para stdout) é de sete linhas durante a semana e a temperatura em graus centígrados

Os dias da semana começam no dia da semana de entrada

As temperaturas são números aleatórios com o intervalo dependendo da estação

Primavera 10-30 graus  
Verão 20-40 graus  
Outono 5 - 25 graus (outono é sinônimo de outono)
Inverno -5 - 15 graus

Entrada de amostra

Thursday Winter

Saída de amostra

Quinta-feira -1
Sexta-feira 3
Sábado 8
Domingo 7
Segunda-feira 10
Terça-feira 10
Quarta-feira -1

Seu programa não deve ter saída idêntica toda vez que é executado com a mesma entrada

mordedor
fonte
É suficiente que apenas um dia tenha temperaturas aleatórias? Dessa forma, a saída não será idêntica para cada execução.
21411 hallvabo
1
Eu estive pensando em problemas de marcação e sugeriria que isso é uma simulação de uma previsão.
dmckee --- ex-moderador gatinho
@hallvabo, eu não pretendo adicionar quaisquer condições adicionais para a questão, é o que é :)
gnibbler
FWIW: Pelo menos do ponto de vista da minha solução, é muito mais fácil gerar temperaturas aleatórias para cada dia do que apenas para uma única. Lidar com todos os dias da mesma forma é muito mais fácil e melhor para o golfe.
Joey
Isso é uma piada?
Caracol mecânico

Respostas:

8

Ruby 1.8, 95 caracteres

#!ruby -nrdate
7.times{|i|puts (Date.parse($_)+i).strftime"%A #{"\023\004\016\016\035"[$_[-3]%5]-9+rand(21)}"}

O caractere que escapa dentro da string deve ser substituído pelos caracteres literais que representam.

  • Encontrada uma maneira mais curta de compactar os dados, o Ruby 1.9 teria quatro caracteres a mais agora (adicione .orddepois $_[-3]).
  • 112 -> 105 roubando a idéia de Joey de não dividir a entrada.
  • 105 -> 101. Observe que a primeira linha é realmente analisada pelo próprio interpretador Ruby, portanto funciona até mesmo ao executar a solução como echo "Thursday Winter" | ruby1.8 forecast.rb
  • 101 -> 96. Roubou a idéia de Joey novamente de incorporar as temperaturas em uma string em vez de em uma matriz.
  • Opa, só notei que deveria ser rand (21), não rand (20).
  • 96 -> 95. Espaços em branco desnecessários removidos.
Ventero
fonte
4

Windows PowerShell, 104

[dayofweek]$d,$s=-split$input
(0..6*2)[+$d..(6+$d)]|%{''+[dayofweek]$_,((random 20)-5+'☼

↓'[$s[3]%5])}

As seqüências de caracteres são um pouco nojentas, portanto, uma visualização hexadecimal para sua conveniência:

000: 5B 64 61 79 6F 66 77 65 │ 65 6B 5D 24 64 2C 24 73  [dayofweek]$d,$s
010: 3D 2D 73 70 6C 69 74 24 │ 69 6E 70 75 74 0A 28 30  =-split$input◙(0
020: 2E 2E 36 2A 32 29 5B 2B │ 24 64 2E 2E 28 36 2B 24  ..6*2)[+$d..(6+$
030: 64 29 5D 7C 25 7B 27 27 │ 2B 5B 64 61 79 6F 66 77  d)]|%{''+[dayofw
040: 65 65 6B 5D 24 5F 2C 28 │ 28 72 61 6E 64 6F 6D 20  eek]$_,((random
050: 32 30 29 2D 35 2B 27 0F │ 00 0A 0A 19 27 5B 24 73  20)-5+'☼ ◙◙↓'[$s
060: 5B 33 5D 25 35 5D 29 7D │                          [3]%5])}

História:

  • 2011-02-04 00:16 (179) - Primeira tentativa direta.
  • 04-02-2011 00:20 (155) - Por que combinar nomes de temporadas inteiras quando você pode se dar bem com personagens individuais e uma partida de regex? Não lidará bem com entradas inválidas, mas isso é sempre esperado no golfe.
  • 06-02-2011 13:12 (149) - Livrei-me das $tcoisas que apenas prolongavam.
  • 10-02-2011 22:50 (142) - A geração do nome do dia ficou mais simples. Eu apenas gero uma semana duas vezes, indexo na posição correta e retiro sete itens.
  • 2011-02-10 22:52 (138) - Mover o elenco inicial para a declaração de $dsalva também alguns bytes - e se livrar dele $x.
  • 2011-02-10 23:03 (135) - Movendo o elenco mais adiante no pipeline para evitar um elenco de matriz (que precisa de mais []). Também alterou a saída para converter uma lista de objetos em string que insere implicitamente um espaço ( $OFSpadrão).
  • 11-02-2011 20:54 (132) - Substituiu a correspondência regex por uma lista de códigos de caracteres e indexação em um hashmap com o terceiro caractere da temporada.
  • 11-02-2011 21:00 (122) - Substituiu o mapa de hash por uma matriz.
  • 11-02-2011 21:12 (117) - Mais bondade e disposição. E mais curto para inicializar. O módulo 8 embala a matriz um pouco mais curta.
  • 11-02-2011 21:16 (116) - Extraiu um fator de cinco para substituir 0,0,2pelo 0..2qual é mais curto.
  • 11-02-2011 21:22 (114) - Usou um cálculo ligeiramente diferente. Ele ainda mapeia o outono e cai para o mesmo índice e tem a vantagem de exigir apenas cinco valores. Muito agradável. O índice negativo na string também é muito bom, com »Fall« sendo mais curto que o resto.
  • 11-02-2011 21:45 (112) - A maneira roubada de Ventero de determinar a faixa de temperatura da estação que é dois bytes mais curta.
  • 12-02-2011 03:16 (105) - Voltar para 105 após uma tentativa diferente de imprimir uma única linha.
  • 12-02-2011 13:23 (104) - De volta a 104 novamente, usando um índice positivo na temporada desde que eu me dividi novamente.

Script de teste (desde que não produza nada, o resultado está ok):

foreach ($d in 'Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday') {
    foreach ($s in 'Winter','Summer','Spring','Autumn','Fall') {
        $o=-split("$d $s"|./weather_foo.ps1)
        if ($o.Count -ne 14) { "Wrong output length" }
        $days = $o -notmatch '\d'
        $temps = $o -match '\d'
        if ($days[0]-ne$d) { "Found "+ $days[0] + " instead of $d" }
        $m = $temps | measure -min -max
        switch ($s) {
            'Summer'{ $min = 20 }
            'Spring'{ $min = 10 }
            'Fall'  { $min = 5  }
            'Autumn'{ $min = 5  }
            'Winter'{ $min = -5 }
        }

        if ($m.Minimum -lt $min) { "Minimum temperature $($m.Minimum) didn't match for $s" }
        if ($m.Maximum -gt $min + 20) { "Maximum temperature $($m.Maximum) didn't match for $s" }
    }
}
Joey
fonte
3

Golfscript - 110 caracteres

' ':^/){*}*43845%7&5*:|;){*}*333121%7&:$;7,{($+'Sun Mon Tues Wednes Thurs Fri Satur'^/.+='day '+20rand|+5-+n}/
  • Suporta totalmente todas as faixas de temperatura, estações e também suporta "Fall" como sinônimo de "Autumn" também.
  • Eu acho que há algumas áreas para melhorias, mas meu conhecimento atual sobre golfe é limitado até o momento.

Aqui estão os testes, 2 passes cada para confirmar a aleatoriedade

$ echo -n Thursday Spring | gs codegolf-404.gs
Thursday 23
Friday 28
Saturday 25
Sunday 22
Monday 19
Tuesday 14
Wednesday 25

$ echo -n Thursday Spring | gs codegolf-404.gs
Thursday 27
Friday 12
Saturday 26
Sunday 12
Monday 27
Tuesday 17
Wednesday 21


$ echo -n Friday Autumn | gs codegolf-404.gs
Friday 10
Saturday 5
Sunday 17
Monday 24
Tuesday 24
Wednesday 12
Thursday 18

$ echo -n Friday Autumn | gs codegolf-404.gs
Friday 13
Saturday 7
Sunday 14
Monday 6
Tuesday 14
Wednesday 21
Thursday 5


$ echo -n Sunday Summer | gs codegolf-404.gs
Sunday 39
Monday 31
Tuesday 35
Wednesday 34
Thursday 21
Friday 36
Saturday 28

$ echo -n Sunday Summer | gs codegolf-404.gs
Sunday 34
Monday 20
Tuesday 30
Wednesday 39
Thursday 30
Friday 31
Saturday 37


$ echo -n Monday Fall | gs codegolf-404.gs
Monday 6
Tuesday 7
Wednesday 18
Thursday 13
Friday 7
Saturday 5
Sunday 14

$ echo -n Monday Fall | gs codegolf-404.gs
Monday 16
Tuesday 22
Wednesday 19
Thursday 23
Friday 21
Saturday 9
Sunday 17


$ echo -n Saturday Winter | gs codegolf-404.gs
Saturday 0
Sunday -5
Monday 10
Tuesday -3
Wednesday -5
Thursday 13
Friday -1

$ echo -n Saturday Winter | gs codegolf-404.gs
Saturday -4
Sunday 13
Monday 11
Tuesday 0
Wednesday 0
Thursday -5
Friday 9


$ echo -n Tuesday Summer | gs codegolf-404.gs
Tuesday 38
Wednesday 29
Thursday 25
Friday 29
Saturday 34
Sunday 20
Monday 39

$ echo -n Tuesday Summer | gs codegolf-404.gs
Tuesday 33
Wednesday 26
Thursday 31
Friday 37
Saturday 39
Sunday 24
Monday 28


$ echo -n Wednesday Winter | gs codegolf-404.gs
W    ednesday 7
Thursday 12
Friday 0
Saturday -3
Sunday 11
Monday 14
Tuesday 8

$ echo -n Wednesday Winter | gs codegolf-404.gs
Wednesday 0
Thursday -1
Friday 7
Saturday 12
Sunday -5
Monday -3
Tuesday 2
VOCÊ
fonte
2

D: 436 caracteres

import std.algorithm, std.random, std.range, std.stdio, std.typecons;

void main(string[] g)
{
    alias canFind w;
    alias tuple t;

    auto s = g[2];
    auto e = w(s, "g") ? t(10, 30) : w(s, "Su") ? t(20, 40) : w(s, "W") ? t(-5, 15) : t(5, 25) ;
    auto r = rndGen();

    int v()
    {
        r.popFront();
        return e[0] + cast(int)(r.front % (e[1] - e[0]));
    }

    auto x = findSplitBefore(["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], [g[1]]);

    foreach(q; chain(x[1], x[0]))
        writefln("%s %s", q, v());
}

Versão com espaço em branco estranho removido (que é como se trata de 436 caracteres):

import std.algorithm,std.random,std.range,std.stdio,std.typecons;void main(string[] g){alias canFind w;alias tuple t;auto s=g[2];auto e=w(s,"g")?t(10,30):w(s,"Su")?t(20,40):w(s,"W")?t(-5,15):t(5,25);auto r=rndGen();int v(){r.popFront();return e[0]+cast(int)(r.front%(e[1]-e[0]));}auto x=findSplitBefore(["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],[g[1]]);foreach(q;chain(x[1],x[0]))writefln("%s %s",q,v());}
Jonathan M Davis
fonte
Certamente, você pode salvar muitos caracteres pressionando todas as novas linhas e recuos, e a maioria dos outros espaços, fora? ;-)
Chris Jester-Young
Contei os caracteres com todo o espaço em branco extra removido. É tão difícil ler dessa maneira que parecia bobagem publicá-la dessa maneira.
Jonathan M Davis
2

PHP, 353 319 305 304 288 caracteres

<?$i=split(" ",fgets(STDIN));$d=$i[0][0].$i[0][1];$s=$i[1][2];$r=json_decode('{"i":[10,30],"m":[20,40],"t":[5,25],"n":[-5,15]}',true);$n=array(Sun,Mon,Tues,Wednes,Thurs,Fri,Satur);$z=$x=0;while($z<7)if($n[++$x][0].$n[$x][1]==$d||$z){$z++;echo$n[$x%7]."day ".rand($r[$s][0],$r[$s][1])."
";}

Ungolfed

<?php
    $input = fgets(STDIN);
    $info = split(" ", $input);
    $day = substr($info[0], 0, 2);
    $season = $info[1][2];
    $range[i][] = 10;
    $range[i][] = 30;
    $range[m][] = 20;
    $range[m][] = 40;
    $range[t][] = 5;
    $range[t][] = 25;
    $range[n][] = -5;
    $range[n][] = 15;
    $days[0] = "Sun";
    $days[1] = "Mon";
    $days[2] = "Tues";
    $days[3] = "Wednes";
    $days[4] = "Thurs";
    $days[5] = "Fri";
    $days[6] = "Satur";

    $i = $d = 0;

    while($i<7)
        if(substr($days[++$d], 0, 2)==$day||$i){
            $i++;
            echo $days[$d%7]."day ".rand($range[$season][0], $range[$season][1])."\n";
        }
?>

305 -> 304: Comutada a nova linha
304 -> 288: Usa matrizes JSON em vez de matrizes PHP

Kevin Brown
fonte
1
Não aceita Fallcomo sinônimo o Autumnespecificado na descrição da tarefa.
Joey
1

Personagens C # 350

Deve haver uma maneira mais eficiente do que isso. Mas aqui está o que eu tenho até agora:

using System;class P{static void Main(string[]x){var r=new Random();var s=x[1][2];int l=s=='r'?10:s=='m'?20:s=='n'?-5:5,u=s=='r'?31:s=='m'?41:s=='n'?16:26,i=0,z=(int)Enum.Parse(typeof(DayOfWeek),x[0]);for(;i<7;i++){var d=z<1?"Sun":z<2?"Mon":z<3?"Tues":z<4?"Wednes":z<5?"Thurs":z<6?"Fri":"Satur";Console.WriteLine(d+"day "+r.Next(l,u));z=z>5?0:z+1;}}}

Ou em um formato mais legível, com alguns comentários:

using System;
class P 
{
    static void Main(string[] x) 
    {
        var r = new Random();
        var s = x[1][2]; //3rd char of season, first where all have unique letter

   // lower & upper limits for random, based on season
        int l = s == 'r' ? 10 : s == 'm' ? 20 : s == 'n' ? -5 : 5, 
            u = s == 'r' ? 31 : s == 'm' ? 41 : s == 'n' ? 16 : 26, 
            i = 0,
   // this line makes me cringe, but converting to an int and back seems
   // the easiest way to loop through days
            z = (int)Enum.Parse(typeof(DayOfWeek), x[0]); 

        for (; i < 7; i++) 
        { 
            var d = z < 1 ? "Sun" : z < 2 ? "Mon" : z < 3 ? "Tues" : z < 4 ? "Wednes" : z < 5 ? "Thurs" : z < 6 ? "Fri" : "Satur";
            Console.WriteLine(d + "day " + r.Next(l, u)); 
            z = z > 5 ? 0 : z + 1; // increments day, resets to 0 after saturday
        }
    }
}
Nellius
fonte
O C # geralmente precisa de toda a ajuda possível, para que você possa substituir o conteúdo do seu loop for por este (acho): Console.WriteLine (Enum.GetName (typeof (DayOfWeek), z ++% 7) + "" + r. Próximo (l, u));
1311 Steve Steve
1

PHP - 150 caracteres

<?$t=array("m"=>15,"r"=>5,"n"=>-10);for($a=split(" ",fgets(STDIN));$i<7;$i++)echo date("l ",strtotime($a[0]."+$i day")),rand(5,25)+$t[$a[1][2]],"\n";

Imaginei que escreveria minha própria solução PHP depois que a atual nem sequer satisfaz totalmente as condições do desafio.

Ele depende do tempo de duração para analisar o dia e da data para repetir o mesmo. Para determinar a estação, segue a terceira letra do nome da estação, que é única (conforme fornecido).

Para funcionar corretamente, é necessário desabilitar avisos e habilitar tags curtas.

Tyzoid
fonte
0

Javascript - 251 caracteres

d=['Mon','Tues','Wednes','Thurs','Fri','Satur','Sun'],g=function(c){return Math.random()*21+c|0},p=prompt();for(i=0,j=7,t=true;i<j;i++){t=t&&p.indexOf(d[i])!=0;t?j++:console.log(d[i>6?i-7:i]+'day '+g(/mm/.test(p)?20:/g/.test(p)?10:/te/.test(p)?-5:5))}

Infelizmente, o script não atende ao requisito stdin / stdout, mas aceita Fall como sinônimo de Autumn.

Espaços em branco:

  d = [
    'Mon'
  , 'Tues'
  , 'Wednes'
  , 'Thurs'
  , 'Fri'
  , 'Satur'
  , 'Sun'
  ]
, g = function(c) {
    return Math.random()*21+c|0
  }
, p = prompt()

  ;

  for(i = 0, j = 7, t = true; i < j; i++) {
    t = t && p.indexOf(d[i]) != 0; 
    t ? 
      j++ : 
      console.log(d[i > 6 ? i - 7 : i] + 'day ' + g(/mm/.test(p) ? 
                                                      20 : 
                                                    /g/.test(p) ? 
                                                      10 : 
                                                    /te/.test(p) ? 
                                                      -5 : 
                                                      5
                                                    )
                  )
  }
codeporn
fonte
0

Mathematica 218

s_~g~d_ := 
Grid@RotateLeft[r = Thread@{DateString[{2012, 1, #}, {"DayName"}] & /@ Range@7, 
  RandomInteger[Cases[{{"Spring", {10, 30}}, {"Summer", {20, 40}}, {"Autumn", {5, 25}}, 
  {"Winter", {-5, 15}}}, {s, _}][[1, 2]], 7]}, Position[r, d][[1, 1]] - 1]

Uso

g["Winter", "Sunday"]

insira a descrição da imagem aqui

DavidC
fonte
0

Python 2, 220 caracteres

Um pouco grande, mas (quase) legível.

import random
c,e=raw_input().split()
a=[d+'day'for d in'Mon Tues Wednes Thurs Fri Satur Sun'.split()]*2
x='rmtn'.index(e[2])*2
g=(10,30,20,40,5,25,-5,15)[x:x+2]
f=a.index(c)
for b in a[f:f+7]:
 print b,random.randint(*g)

Resultado

# echo "Monday Summer" | python forecast.py 
Monday 33
Tuesday 29
Wednesday 33
Thursday 28
Friday 25
Saturday 21
Sunday 30
Cavaleiro Lógico
fonte