Prognozuj pogodę

13

Napisz najkrótszy program do prognozowania pogody na następne 7 dni

Dane wejściowe (od standardowego) to dzień tygodnia i pora roku

Wyjście (na standardowe wyjście) to siedem wierszy w dzień powszedni i temperatura w stopniach Celsjusza

Dni powszednie rozpoczynają się od wejściowego dnia tygodnia

Temperatury są liczbami losowymi, których zakres zależy od sezonu

Wiosna 10-30 stopni  
Lato 20 - 40 stopni  
Jesień 5 - 25 stopni (jesień to synonim jesieni)
Zima -5 - 15 stopni

Przykładowe dane wejściowe

Thursday Winter

Przykładowe dane wyjściowe

Czwartek -1
Piątek 3
Sobota 8
Niedziela 7
Poniedziałek 10
Wtorek 10
Środa -1

Twój program nie może mieć identycznego wyjścia za każdym razem, gdy jest uruchamiany z tym samym wejściem

gnibbler
źródło
Czy wystarczy, że tylko jeden dzień ma losowe temperatury? W ten sposób dane wyjściowe nie będą identyczne dla każdego uruchomienia.
hallvabo
1
Zastanawiałem się nad tagowaniem problemów i sugerowałbym, że jest to symulacja prognozy czy.
dmckee --- były moderator kociak
@hallvabo, nie zamierzam dodawać żadnych dodatkowych warunków do pytania, tak to jest :)
gnibbler
FWIW: Przynajmniej z punktu widzenia mojego rozwiązania o wiele łatwiej jest generować losowe temperatury dla każdego dnia niż dla jednego. Postępowanie przez te same dni jest o wiele łatwiejsze i lepsze w golfa.
Joey,
Czy to żart?
Ślimak mechaniczny

Odpowiedzi:

8

Ruby 1.8, 95 znaków

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

Znak ucieka wewnątrz ciągu należy zastąpić literałami znaku, które reprezentują.

  • Znalazłem krótszy sposób na spakowanie danych, Ruby 1.9 miałby teraz 4 znaki dłużej (dodaj .ordpo $_[-3]).
  • 112 -> 105, kradnąc pomysł Joeya, by nie dzielić danych wejściowych.
  • 105 -> 101. Zauważ, że pierwszy wiersz jest faktycznie analizowany przez sam interpreter Ruby, więc działa nawet podczas uruchamiania rozwiązania takiego jak echo "Thursday Winter" | ruby1.8 forecast.rb
  • 101 -> 96. Ponownie ukradł pomysł Joey'a, aby po prostu osadzić temperatury w ciągu zamiast w tablicy.
  • Ups, właśnie zauważyłem, że powinien to być rand (21), a nie rand (20).
  • 96 -> 95. Usunięto niepotrzebne białe znaki.
Ventero
źródło
4

Windows PowerShell, 104

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

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

Ciągi tam są trochę obrzydliwe, więc widok szesnastkowy dla Twojej wygody:

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])}

Historia:

  • 2011-02-04 00:16 (179) - Pierwsza prosta próba.
  • 2011-02-04 00:20 (155) - Po co dopasowywać nazwy całego sezonu, skoro można uciec od pojedynczych postaci i dopasowania wyrażenia regularnego? Nie poradzi sobie dobrze z nieprawidłowymi danymi wejściowymi, ale zawsze należy się tego spodziewać w golfie.
  • 2011-02-06 13:12 (149) - Pozbyłem się $ttylko tego, co wydłużyło.
  • 2011-02-10 22:50 (142) - Uproszczono generowanie nazw dni. Generuję tylko tydzień dwa razy, indeksuję we właściwej pozycji i wyciągam siedem pozycji.
  • 2011-02-10 22:52 (138) - Przeniesienie początkowej obsady do deklaracji $doszczędza również kilka bajtów - i się jej pozbywa $x.
  • 2011-02-10 23:03 (135) - Przesunięcie rzutowania dalej w dół potoku, aby uniknąć rzutowania macierzy (co wymaga dodatkowych []). Zmieniono także dane wyjściowe na rzutowanie listy obiektów na ciąg znaków, który domyślnie wstawia spację ( $OFSdomyślnie).
  • 2011-02-11 20:54 (132) - Zamieniono dopasowanie wyrażenia regularnego na listę kodów znaków i indeksuje w haszap z trzecią postacią z sezonu.
  • 2011-02-11 21:00 (122) - Zastąpiono mapę skrótu tablicą.
  • 2011-02-11 21:12 (117) - Większa dobroć. I krótszy do rozruchu. Modulo 8 pakuje tablicę nieco krócej.
  • 11.02.2011 21:16 (116) - Wyekstrahowane pięciokrotnie zastąpić 0,0,2przez 0..2który jest krótszy.
  • 2011-02-11 21:22 (114) - Zastosowano nieco inne obliczenia. Nadal mapuje jesień i jesień do tego samego indeksu i ma tę zaletę, że wymaga tylko pięciu wartości. Bardzo dobrze. Negatywny indeks ciągu również odgrywa bardzo dobrą rolę, ponieważ „Fall” jest krótszy niż reszta.
  • 2011-02-11 21:45 (112) - Skradziony sposób Ventero na określenie zakresu temperatur sezonu, który jest o dwa bajty krótszy.
  • 2011-02-12 03:16 (105) - Powrót do 105 po innej próbie wydrukował tylko jedną linię.
  • 2011-02-12 13:23 (104) - Z powrotem do 104, używając dodatniego indeksu do sezonu, odkąd znów się rozdzieliłem.

Skrypt testowy (o ile nic nie wyświetla, wynik jest w porządku):

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

Golfscript - 110 znaków

' ':^/){*}*43845%7&5*:|;){*}*333121%7&:$;7,{($+'Sun Mon Tues Wednes Thurs Fri Satur'^/.+='day '+20rand|+5-+n}/
  • W pełni obsługuj wszystkie zakresy temperatur, pory roku, a także wspieraj „Fall” jako synonim „Autumn”.
  • Myślę, że jest kilka sposobów na poprawę, ale moja obecna wiedza na temat gry w golfa jest jak dotąd ograniczona.

Oto testy, po 2 testy w celu potwierdzenia losowości

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

D: 436 znaków

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

Wersja z usuniętymi obcymi białymi spacjami (tak jest w przypadku 436 znaków):

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
źródło
Z pewnością możesz uratować wiele postaci, wyciskając wszystkie znaki nowej linii i wcięcia oraz większość innych spacji? ;-)
Chris Jester-Young
Policzyłem postacie z usuniętą dodatkową spacją. Tak trudno jest czytać w ten sposób, że publikowanie go w ten sposób wydawało się głupie.
Jonathan M. Davis
2

PHP, 353 319 305 304 288 znaków

<?$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])."
";}

Nie golfił

<?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: Przełączono nowy wiersz
304 -> 288: Używa tablic JSON zamiast tablic PHP

Kevin Brown
źródło
1
Nie akceptuje Falljako synonimu Autumnokreślonego w opisie zadania.
Joey,
1

C # 350 znaków

Musi być bardziej skuteczny sposób niż ten. Ale oto co mam do tej pory:

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

Lub w bardziej czytelnym formacie, z kilkoma komentarzami:

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
źródło
C # zwykle potrzebuje całej pomocy, jaką może uzyskać, więc możesz zastąpić zawartość swojej pętli for następującą (tak myślę): Console.WriteLine (Enum.GetName (typeof (DayOfWeek), z ++% 7) + "" + r. Dalej (1, u));
Steve,
1

PHP - 150 znaków

<?$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";

Pomyślałem, że napiszę własne rozwiązanie PHP, gdy obecne nie spełnia nawet w pełni warunków wyzwania.

Polega na strtotime do parsowania dnia i daty, aby powtórzyć go z powrotem. Aby określić sezon, następuje trzecia litera nazwy sezonu, która jest unikalna (jak podano).

Do poprawnego działania wymaga wyłączenia powiadomień i włączenia krótkich tagów.

Tyzoid
źródło
0

JavaScript - 251 znaków

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

Niestety skrypt nie spełnia wymagań stdin / stdout, ale akceptuje Fall jako synonim Autumn.

Białe znaki:

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

Stosowanie

g["Winter", "Sunday"]

wprowadź opis zdjęcia tutaj

DavidC
źródło
0

Python 2, 220 znaków

Trochę duży, ale (prawie) czytelny.

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)

Wynik

# echo "Monday Summer" | python forecast.py 
Monday 33
Tuesday 29
Wednesday 33
Thursday 28
Friday 25
Saturday 21
Sunday 30
Logic Knight
źródło