Previsioni il tempo


13

Scrivi il programma più breve per prevedere il tempo per i prossimi 7 giorni

L'input (da stdin) è il giorno della settimana e la stagione

L'output (su stdout) è di sette righe nei giorni feriali e la temperatura in gradi centigradi

I giorni della settimana iniziano il giorno della settimana di input

Le temperature sono numeri casuali con l'intervallo a seconda della stagione

Primavera 10-30 gradi  
Estate 20 - 40 gradi  
Autunno 5 - 25 gradi (L'autunno è sinonimo di autunno)
Inverno -5 - 15 gradi

Input di esempio

Thursday Winter

Uscita campione

Giovedì -1
Venerdì 3
Sabato 8
Domenica 7
Lunedì 10
Martedì 10
Mercoledì -1

Il tuo programma non deve avere un output identico ogni volta che viene eseguito con lo stesso input


È sufficiente che solo un giorno abbia temperature casuali? In questo modo, l'output non sarà identico per ogni corsa.
hallvabo,

1
Ho pensato di taggare i problemi e suggerirei che questa è una simulazione di una previsione if.
dmckee --- ex gattino moderatore

@hallvabo, non intendo aggiungere ulteriori condizioni alla domanda, è quello che è :)
Gnibbler,

FWIW: Almeno dal punto di vista della mia soluzione è molto più semplice generare temperature casuali per ogni giorno piuttosto che per una sola. Gestire tutti i giorni lo stesso è molto più facile e migliore per giocare a golf.
Joey,

È uno scherzo?
Lumaca meccanica il

Risposte:


8

Ruby 1.8, 95 caratteri

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

Il carattere che fuoriesce all'interno della stringa deve essere sostituito dai caratteri letterali che rappresentano.

  • Trovato un modo più breve per impacchettare i dati, Ruby 1.9 ora sarebbe più lungo di 4 caratteri (aggiungi .orddopo $_[-3]).
  • 112 -> 105 rubando l'idea di Joey di non dividere l'input.
  • 105 -> 101. Si noti che la prima riga è effettivamente analizzata dall'interprete Ruby stessa, quindi funziona anche quando si esegue la soluzione come echo "Thursday Winter" | ruby1.8 forecast.rb
  • 101 -> 96. Ho rubato di nuovo l'idea di Joey di incorporare le temperature in una stringa anziché in un array.
  • Spiacenti, ho appena notato che dovrebbe essere Rand (21), non Rand (20).
  • 96 -> 95. Spazio bianco non necessario rimosso.

4

Windows PowerShell, 104

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

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

Le stringhe sono un po 'icky, quindi una vista esadecimale per tua comodità:

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

Storia:

  • 04/02/2011 00:16 (179) - Primo tentativo diretto.
  • 04/02/2011 00:20 (155) - Perché abbinare i nomi di intere stagioni quando puoi cavartela con singoli personaggi e una partita regex? Non si occuperà bene di input non validi, ma questo è sempre prevedibile nel golf.
  • 06/02/2011 13:12 (149) - Mi sono sbarazzato $tsolo delle cose allungate.
  • 10/02/2011 22:50 (142) - La generazione del nome del giorno è stata semplificata. Genero solo una settimana due volte, indicizzo nella posizione corretta ed estraggo sette elementi.
  • 10/02/2011 22:52 (138) - Spostando il cast iniziale nella dichiarazione di si $dsalva anche qualche byte - e si sbarazza di $x.
  • 2011-02-10 23:03 (135) - Spostare il cast più in basso lungo la pipeline per evitare un cast dell'array (che necessita di ulteriore []). Anche l'output è stato modificato in casting di un elenco di oggetti su stringa che inserisce implicitamente uno spazio ( $OFSimpostazione predefinita).
  • 2011-02-11 20:54 (132) - Sostituito l'incontro regex con un elenco di codici personaggio e indicizzazione in una hashmap con il terzo personaggio della stagione.
  • 2011-02-11 21:00 (122) - Sostituita la mappa hash con un array.
  • 2011-02-11 21:12 (117) - Più bontà di array-y. E più breve per l'avvio. Modulo 8 rende l'array un po 'più breve.
  • 2011-02-11 21:16 (116) - Estratto un fattore di cinque da sostituire 0,0,2con il 0..2quale è più breve.
  • 2011-02-11 21:22 (114) - Utilizzato un calcolo leggermente diverso. Mappa ancora l'autunno e rientra nello stesso indice e ha il vantaggio di richiedere solo cinque valori. Molto bella. Anche l'indice negativo nella stringa suona molto bene con »Fall« più corto del resto.
  • 2011-02-11 21:45 (112) - Il modo di Ventero rubato di determinare l'intervallo di temperature della stagione che è di due byte in meno.
  • 12/02/2011 03:16 (105) - Torna a 105 dopo un altro tentativo appena stampato una sola riga.
  • 12/02/2011 13:23 (104) - Di nuovo a 104, usando un indice positivo nella stagione da quando mi sono diviso di nuovo.

Script di test (purché non produca nulla il risultato è 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" }
    }
}

3

Golfscript - 110 caratteri

' ':^/){*}*43845%7&5*:|;){*}*333121%7&:$;7,{($+'Sun Mon Tues Wednes Thurs Fri Satur'^/.+='day '+20rand|+5-+n}/
  • Supporta pienamente tutti gli intervalli di temperatura, le stagioni e supporta anche "Autunno" come sinonimo di "Autunno".
  • Penso che ci siano alcuni margini di miglioramento, ma la mia attuale conoscenza del campo da golf è finora limitata.

Ecco i test, 2 passaggi ciascuno per confermare la casualità

$ 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

2

D: 436 personaggi

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

Versione con spazi bianchi estranei rimossi (che è come arriva a 436 caratteri):

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

Sicuramente, puoi salvare molti personaggi semplicemente schiacciando tutte le nuove linee e il rientro, e la maggior parte degli altri spazi, fuori? ;-)
Chris Jester-Young,

Ho contato i personaggi con tutto lo spazio bianco in più rimosso. È così difficile leggere in quel modo che sembrava sciocco postarlo in quel modo.
Jonathan M Davis,

2

PHP, 353 319 305 304 288 caratteri

<?$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: ha cambiato la nuova riga
304 -> 288: utilizza array JSON anziché array PHP


1
Non accetta Fallcome sinonimo Autumncome specificato nella descrizione dell'attività.
Joey,

1

Personaggi C # 350

Deve esserci un modo più efficiente di questo. Ma ecco cosa ho finora:

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

O in un formato più leggibile, con un paio di commenti:

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

C # di solito ha bisogno di tutto l'aiuto possibile, quindi puoi sostituire il contenuto del tuo ciclo for con questo (credo): Console.WriteLine (Enum.GetName (typeof (DayOfWeek), z ++% 7) + "" + r. Avanti (l, u));
Steve,

1

PHP - 150 personaggi

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

Ho pensato di scrivere la mia soluzione PHP dopo che quella attuale non soddisfaceva nemmeno completamente le condizioni della sfida.

Si basa sullo strtotime per analizzare il giorno e la data per riecheggiarlo. Per determinare la stagione, segue la terza lettera del nome della stagione, che è unica (come indicato).

Per funzionare correttamente, richiede che gli avvisi siano disabilitati e che i tag brevi siano abilitati.


0

Javascript - 251 caratteri

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

Sfortunatamente lo script non soddisfa il requisito stdin / stdout ma accetta Fall come sinonimo di Autunno.

Whitespaced:

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

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"]

inserisci qui la descrizione dell'immagine


0

Python 2, 220 caratteri

Un po 'grande ma (quasi) leggibile.

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)

Produzione

# echo "Monday Summer" | python forecast.py 
Monday 33
Tuesday 29
Wednesday 33
Thursday 28
Friday 25
Saturday 21
Sunday 30
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.