Что будет на вершине этого декоративного календаря?

14

Кто-то подарил моей жене декоративный календарь, состоящий из четырех кубиков. Здесь она показывает сегодняшнюю дату (на момент публикации этой задачи) на передней панели:

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

Когда я впервые увидел это, я посмотрел на него под неправильным углом (прямо сверху) и не мог понять, почему он дал эту информацию:

[["February", "January"], [3], [7], ["Monday", "Tuesday"]]

Ваша задача - повторить мою ошибку на любую дату в 2019 году.

Вызов

Напишите программу или функцию, которая берет любую дату с 2019 года и выводит то, что появляется в верхней части всех кубов, когда эта дата отображается лицевой стороной к календарю.

Вот все шесть граней для всех кубов. Для отображения 6вы просто переверните 9вверх дном. 0Вертикально симметричны, так что 0вниз по - прежнему 0. Для некоторых дат может быть более одного правильного ответа (например, у любого 11-го числа любого месяца будет более одного способа использования кубов и тому 0подобное), поэтому вы можете вывести любой правильный ответ.

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

правила

  1. Стандартные лазейки запрещены.
  2. Формат ввода / вывода гибкий.
  3. Вывод должен быть в порядке по кубу, но не внутри куба. Порядок должен быть сначала кубом месяца, затем двумя числовыми кубами, а затем кубом дня недели. Но когда куб имеет два элемента сверху, эти два элемента могут быть в любом порядке.
  4. Вы можете заменить Januaryна December0-11 или 1-12, если хотите.
  5. Вы можете заменить дни недели с 0-6 или 1-7 , если вы хотите, и вы можете начать неделю на любом SundayилиMonday (но вы не можете начать неделю с другого дня - это PPGC, а не какой-то другой). сумасшедшего города.)
  6. Это . Побеждает меньшее количество байтов для каждого языка.
  7. Пояснения приветствуются.

Контрольные примеры

(Tue) 2019-01-29   [[ "July", "August" ], [3], [7], [ "Thursday", "Wednesday" ]]
                   [[ "August", "July" ], [3], [7], [ "Wednesday", "Thursday" ]]

                   etc. since the order within each cube doesn't matter.


(Thu) 2019-07-11   [[ "May", "June" ], [3], [8], [ "Saturday", "Friday" ]]
                   [[ "May", "June" ], [8], [3], [ "Saturday", "Friday" ]]

                   since the two 1 cubes could be either way.

(Sun) 2019-10-27   [[ "January", "February" ], [3], [6], [ "Friday", "Saturday" ]]

(Wed) 2019-05-01   [[ "March", "April" ], [8], [3], [ "Monday", "Tuesday" ]]
                   [[ "March", "April" ], [6], [3], [ "Monday", "Tuesday" ]]
                   [[ "March", "April" ], [9], [3], [ "Monday", "Tuesday" ]]

                   since the 0 cube could have either the 8 side or the 6 side facing up, and the 6 could also be considered a 9.


(Sat) 2019-08-24   [[ "February", "January" ], [8], [5], [ "Sunday" ]]
НГМ
источник
Итак ... Мне было интересно, как эта декоративная вещь способна показать все даты?
Эрик Outgolfer
@ErikTheOutgolfer какая дата отсутствует?
НГМ
Не связано с вызовом, но, поскольку я не могу пинговать вас через чат, как вы используете два средних куба? Я имею в виду, что все 10 цифр должны быть представлены.
Эрик Outgolfer
1
Кубики можно использовать в любом порядке. Давайте назовем два числовых куба сверху справа и снизу слева, как на рисунке. Чтобы получить 18 вы используете 1 сверху справа и 8 снизу слева. Чтобы получить 13, вы используете 1 снизу слева и 3 сверху справа. И так далее. 0 1 и 2 должны быть на обоих кубах. Тот факт, что 6 и 9 имеют одну и ту же грань куба, дает вам все от 01 до 31, и это все, что нужно.
НГМ
1
Согласно фотографиям, 27в 2019-10-27должен идти 36, нет 32.
Джап

Ответы:

5

C (glibc) , 327 319 286 байт

#define C strftime(s
#define U(B,E)S[6]=E-1,C+B,99,"%A"+2*!E,S)
S[9],s[99];f(M,D){S[4]=112233107696>>3*M&7;C,9,"%B",S);S[4]^=1;
C+3,9,"%B",S);M=161102>>(D+M*23/9-1-2*(M>2))%7*3&7;U(6,M);U(9,(M^1));
printf("%s/%s %d%d %s/%s\n",
s,s+3,D>29?4:D%10<6?8:3,D>29?8:1070160091>>D%10*3&7,s+6,s+9);}

(Для ясности добавлены некоторые разрывы строк)

fзанимает месяц (1–12) и день (1–31). Печать на стандартный вывод. Попробуйте онлайн!

Тестовые случаи:

2019-01-29: July/August 37 Thursday/Wednesday
2019-07-11: May/June 83 Saturday/Friday
2019-10-27: January/February 36 Friday/Saturday
2019-05-01: March/April 83 Monday/Tuesday
2019-08-24: February/January 85 /Sunday

Ungolfed

#include <stdio.h>
#include <time.h>
void f(int M, int D) {
    int month_cube[] = {6,3,0,5,2,7,4,1,4,0,5,1};
    int day_cube[] = {3,3,3,4,5,2,2,6,7,7};
    int week_cube[] = {6,1,5,2,7,4,0}; /* 1=Sun, 7=Sat, 0=none */
    int D1 = D/10, D2 = D%10;
    char s[4][99] = {{0}};
    struct tm t;

    t.tm_mon = month_cube[M-1];
    strftime(s[0], 99, "%B", &t);
    t.tm_mon = month_cube[M-1]^1;
    strftime(s[1], 99, "%B", &t);

    if (D1 >= 3) { /* D = 30, 31 */
        D1 = 4, D2 = 8;
    } else {
        if (D2 <= 5) {
            D1 = 8; /* 012[69]78: 012 -> 8 */
        } else {
            D1 = 3; /* 012345: 012 -> 3 */
        }
        D2 = day_cube[D2];
    }

    int W = (D + M*23/9 - 1 - 2*(M>2)) % 7; /* day of week */
    if (week_cube[W]) {
        t.tm_wday = week_cube[W] - 1;
        strftime(s[2], 99, "%A", &t);
    }
    if (week_cube[W]^1) {
        t.tm_wday = (week_cube[W]^1) - 1;
        strftime(s[3], 99, "%A", &t);
    }

    printf("%s/%s %d%d %s/%s\n", s[0], s[1], D1, D2, s[2], s[3]);
}

Цифровые кубики

Вот возможности для цифр:

Cube 1:
0 1 2 3 4 5
3 3 3 4 5 2
5

Cube 2:
0 1 2        6 7 8 9
8 8 8        2 6 7 7
6                2
9

Следующее отображение кажется лучшим выбором для игры в гольф:

   01 02 03 04 05 06 07 08 09
   83 83 84 85 82 32 36 37 37

10 11 12 13 14 15 16 17 18 19
83 83 83 84 85 82 32 36 37 37

20 21 22 23 24 25 26 27 28 29
83 83 83 84 85 82 32 36 37 37

30 31
48 48

Коды

strftimeпредназначен для вызова с struct tmвходом. Вместо этого я заявляю int S[9]и использую S[4]как tm_monи S[6]как tm_wday. Это работает, если библиотека C использует тот же список членов структуры, что и стандарт ISO.

s[99]используется для хранения различных строк из strftime, но создание intмассива экономит несколько байтов при индексации.

JAPH
источник
3

JavaScript (ES6), 142 байта

Принимает входные данные как (year, month, day0, day1)гдемоNTчас индексируется 1, daY0 первая цифра даты и daY1 это вторая цифра.

Возвращает, (month0, month1, day0, day1, weekDay0, weekDay1)когда дни недели 0 индексируются с0на воскресенье. Если день второй недели пуст, он устанавливается на-1,

(y,m,t,u)=>[M=-~((s='45226276204264')[m--+6]||4*m%2),M+1,t<3?u<6?8:3:s[t-3],u<3?3:s[u-3],D=s[(new Date(y,m,t*10+u).getDay()+6)%7+7],-~D%7||-1]

Попробуйте онлайн!

Arnauld
источник