Прогноз погоды


13

Напишите самую короткую программу для прогноза погоды на ближайшие 7 дней

Ввод (из стандартного ввода) - день недели и сезон

Выход (в стандартный вывод) - семь строк в будний день и температура в градусах Цельсия.

Будни начинаются с ввода дня недели

Температуры являются случайными числами с диапазоном в зависимости от сезона

Весна 10 - 30 градусов  
Лето 20 - 40 градусов  
Осень 5 - 25 градусов (осень - синоним осени)
Зима -5 - 15 градусов

Пример ввода

Thursday Winter

Пример вывода

Четверг -1
Пятница 3
Суббота 8
Воскресенье 7
Понедельник 10
Вторник 10
Среда -1

Ваша программа не должна иметь одинаковый вывод при каждом запуске с одним и тем же вводом


Достаточно ли того, что только один день имеет случайные температуры? Таким образом, выходные данные не будут идентичны для каждого прогона.
Hallvabo

1
Я думал о тегировании проблем и предположил бы, что это симуляция прогноза.
dmckee --- котенок экс-модератора

@hallvabo, я не собираюсь добавлять какие-либо дополнительные условия к вопросу, это то, что есть :)
gnibbler

FWIW: По крайней мере, с точки зрения моего решения, гораздо проще просто генерировать случайные температуры для каждого дня, чем для одного. Обрабатывать все дни одинаково намного проще и лучше для гольфа.
Джои

Ответы:


8

Ruby 1.8, 95 символов

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

Символы, выходящие внутри строки, должны быть заменены символьными литералами, которые они представляют.

  • Найденный более короткий способ упаковки данных, Ruby 1.9 теперь будет на 4 символа длиннее (добавьте .ordпосле $_[-3]).
  • 112 -> 105, украдя идею Джои о том, чтобы не разделять ввод.
  • 105 -> 101. Обратите внимание, что первая строка фактически анализируется самим интерпретатором Ruby, поэтому она работает даже при запуске решения, например echo "Thursday Winter" | ruby1.8 forecast.rb
  • 101 -> 96. Снова украл идею Джои, чтобы просто встроить температуру в строку вместо массива.
  • Ой, только что заметил, что это должен быть rand (21), а не rand (20).
  • 96 -> 95. Убраны лишние пробелы.

4

Windows PowerShell, 104

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

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

Строки там немного странные, поэтому для вашего удобства шестнадцатеричное представление:

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

История:

  • 2011-02-04 00:16 (179) - Первая прямолинейная попытка.
  • 2011-02-04 00:20 (155) - Зачем сопоставлять названия целых сезонов, когда вы можете выбраться с отдельными персонажами и совпадением с регулярным выражением? Не будет иметь дело с неправильным вводом, но это всегда следует ожидать в Гольфе.
  • 2011-02-06 13:12 (149) - Избавился от $tчего только удлинил вещи.
  • 2011-02-10 22:50 (142) - Создание названия дня стало проще. Я просто генерирую неделю дважды, индексирую в правильной позиции и вытаскиваю семь элементов.
  • 2011-02-10 22:52 (138) - Перемещение начального приведения к объявлению также $dэкономит несколько байтов - и избавляется от него $x.
  • 2011-02-10 23:03 (135) - Перемещение приведения вниз по конвейеру, чтобы избежать приведения массива (который требует дополнительного []). Также изменен вывод для приведения списка объектов к строке, которая неявно вставляет пробел (по $OFSумолчанию).
  • 2011-02-11 20:54 (132) - Заменено совпадение с регулярным выражением списком кодов символов и индексацией в хэш-карту с третьим символом сезона.
  • 2011-02-11 21:00 (122) - Хеш-карта заменена на массив.
  • 2011-02-11 21:12 (117) - Больше массива-бога. И короче к загрузке. Модуль 8 упаковывает массив немного короче.
  • 2011-02-11 21:16 (116) - Извлечен коэффициент пять для замены 0,0,2на 0..2более короткий.
  • 2011-02-11 21:22 (114) - Использовал немного другой расчет. Он по-прежнему отображает осень и попадает в тот же индекс и имеет преимущество в том, что требуется только пять значений. Очень хорошо. Отрицательный индекс в строке также играет очень хорошо, так как »Fall« короче остальных.
  • 2011-02-11 21:45 (112) - Похищенный Ventero способ определения температурного диапазона сезона, который на два байта короче.
  • 2011-02-12 03:16 (105) - Вернемся к 105 после другой попытки просто напечатать одну строку.
  • 2011-02-12 13:23 (104) - Вернемся к 104 снова, используя положительный индекс в сезоне, так как я снова разделился.

Тестовый скрипт (если он ничего не выводит, результат в порядке):

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 символов

' ':^/){*}*43845%7&5*:|;){*}*333121%7&:$;7,{($+'Sun Mon Tues Wednes Thurs Fri Satur'^/.+='day '+20rand|+5-+n}/
  • Полностью поддерживает все температурные диапазоны, сезоны, а также поддерживает «Осень» как синоним «Осень» тоже.
  • Я думаю, что есть некоторые возможности для совершенствования, но мои текущие знания в области гольфа пока ограничены.

Вот тесты, 2 прохода каждый для подтверждения случайности

$ 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 символов

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

Версия с удаленным лишним пробелом (как это происходит с 436 символами):

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

Конечно, вы можете сохранить много символов, просто сжав все новые строки и отступы, а также большинство других пробелов? ;-)
Крис Шестер-Янг

Я посчитал символы со всеми лишними пробелами. Просто так трудно читать таким образом, что было бы глупо так публиковать.
Джонатан М Дэвис

2

PHP, 353 319 305 304 288 символов

<?$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: переключен перевод строки
304 -> 288: использует массивы JSON вместо массивов PHP


1
Не принимает Fallв качестве синонима, Autumnкак указано в описании задачи.
Джои,

1

C # 350 символов

Должен быть более эффективный способ, чем этот. Но вот что у меня так далеко:

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

Или в более читабельном формате с парой комментариев:

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 # обычно требуется вся помощь, которую он может получить, поэтому вы можете заменить содержимое вашего цикла for следующим (я думаю): Console.WriteLine (Enum.GetName (typeof (DayOfWeek), z ++% 7) + "" + r. Далее (л, у));
Стив

1

PHP - 150 символов

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

Я подумал, что напишу свое собственное PHP-решение после того, как текущее даже не полностью удовлетворит условия вызова.

Он полагается на strtotime для анализа дня и даты, чтобы вернуть его обратно. Для определения сезона следует третья буква названия сезона, которая является уникальной (как дано).

Для правильной работы необходимо отключить уведомления и включить короткие теги.


0

Javascript - 251 символ

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

К сожалению, скрипт не удовлетворяет требованию stdin / stdout, но принимает Fall как синоним Autumn.

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]

использование

g["Winter", "Sunday"]

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


0

Python 2, 220 символов

Немного большой, но (почти) читабельный.

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)

Выход

# echo "Monday Summer" | python forecast.py 
Monday 33
Tuesday 29
Wednesday 33
Thursday 28
Friday 25
Saturday 21
Sunday 30
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.