Určení dne v týdnu - Determination of the day of the week

The stanovení dne v týdnu pro jakékoli datum lze provést s různými algoritmy. Navíc, věčné kalendáře nevyžadují žádný výpočet uživatelem a jsou v zásadě vyhledávacími tabulkami. Typickou aplikací je výpočet den v týdnu na kterém se někdo narodil nebo došlo ke konkrétní události.

Koncepty

V numerickém výpočtu jsou dny v týdnu představovány jako čísla v týdnu. Pokud je pondělí první den v týdnu, mohou být dny kódovány od 1 do 7, od pondělí do neděle, jak se praktikuje v ISO 8601. Den označený 7 lze také započítat jako 0použitím aplikace aritmetické modulo 7, který vypočítá zbytek čísla po dělení 7. S číslem 7 se tedy zachází jako s 0, 8 jako 1, 9 jako 2, 18 jako 4 atd. Pokud se neděle počítá jako den 1, pak o 7 dní později (tj. Den 8) je také neděle a den 18 je stejný jako den 4, což je středa, protože to připadne tři dny po neděli.[1]

StandardpondělíúterýstředaČtvrtekpáteksobotaNedělePříklady použití
ISO 86011234567% _ISODOWI%,% @ ISODOWI []% (4DOS );[2] DEN V TÝDNU() (HP Prime )[3]
0123456
2345671% NDAY WEEK% (NetWare, DR-DOS[4]); % _DOWI%,% @ DOWI []% (4DOS )[2]
1234560Finanční kalkulačky HP

Základní přístup téměř všech metod pro výpočet dne v týdnu začíná tím, že začíná „kotevním datem“: známý pár (například 1. leden 1800 jako středa), který určuje počet dní mezi známým dnem a den, který se pokoušíte určit, a pomocí aritmetického modulo 7 najdete nový číselný den v týdnu.

Jedním standardním přístupem je vyhledat (nebo vypočítat pomocí známého pravidla) hodnotu prvního dne týdne daného století, vyhledat (nebo vypočítat pomocí metody kongruence) úpravu měsíce, vypočítat počet přestupných let od začátku století a poté je sečtěte spolu s počtem let od začátku století a počtem dnů v měsíci. Nakonec jeden skončí počítáním dnů, na které se použije modulo 7 k určení dne v týdnu data.[5]

Některé metody nejprve provedou všechna přidání a poté vyhazují sedmičky, zatímco jiné je vyhazují v každém kroku, jako v Metoda Lewise Carrolla. Oba způsoby jsou docela životaschopné: první je jednodušší pro kalkulačky a počítačové programy, druhý pro mentální výpočet (je docela možné provést všechny výpočty v hlavě s trochou praxe). Žádná z zde uvedených metod neprovádí kontrolu rozsahu, takže nepřiměřená data způsobí chybné výsledky.

Odpovídající dny

Každý sedmý den v měsíci má stejný název jako předchozí:

Den
měsíc
d
00 07 14 21 280
01 08 15 22 291
02 09 16 23 302
03 10 17 24 313
04 11 18 254
05 12 19 265
06 13 20 276

Odpovídající měsíce

„Odpovídající měsíce“ jsou měsíce v kalendářním roce, které začínají ve stejný den v týdnu. Například září a prosinec odpovídají, protože 1. září připadá na stejný den jako 1. prosince (protože mezi těmito dvěma daty je přesně třináct 7denních týdnů). Měsíce mohou odpovídat, pouze pokud je počet dní mezi jejich prvními dny dělitelný 7, nebo jinými slovy, pokud jsou jejich první dny od sebe odděleny celým počtem týdnů. Například únor a běžný rok odpovídá březnu, protože únor má 28 dní, číslo dělitelné 7, 28 dní jsou přesně čtyři týdny přestupný rok „Leden a únor odpovídají jiným měsícům než v běžném roce, protože přidání 29. února znamená, že každý následující měsíc začíná o den později.

Odpovídající měsíce jsou uvedeny níže.

Běžné roky

  • Leden a říjen.
  • Únor, březen a listopad.
  • Dubna a července.
  • Žádný měsíc neodpovídá srpnu.

Přestupné roky

  • Leden, duben a červenec.
  • Únor a srpen.
  • Březen a listopad.
  • Žádný měsíc neodpovídá říjnu.

Všechny roky

  • Září a prosinec.
  • Žádný měsíc neodpovídá květnu nebo červnu.

V níže uvedené tabulce měsíců mají odpovídající měsíce stejný počet, což vyplývá přímo z definice.

Běžné rokyPřestupné rokym
Jan OctŘíjna0
Smět1
SrpenÚnora2
Únor Mar NovMar Nov3
Června4
Září prosinec5
Dubna červenceLedna dubna července6

Odpovídající roky

Existuje sedm možných dnů, kdy rok může začít, a přestupné roky změní den v týdnu po 29. únoru. To znamená, že rok může mít 14 konfigurací. Na všechny konfigurace může odkazovat a dominický dopis Protože ale 29. února nebyl přidělen žádný dopis, přestupný rok má dvě dominantní písmena, jedno pro leden a únor a druhé (jeden krok zpět v abecedním pořadí) pro březen až prosinec.

Například rok 2019 byl a běžný rok začínající v úterý, což naznačuje, že rok jako celek odpovídal roku 2013 kalendářní rok. Na druhou stranu je rok 2020 a přestupný rok začínající ve středu což bude celkově odpovídat kalendářnímu roku 1992; konkrétně jeho první 2 měsíce, s výjimkou 29. února, budou odpovídat měsícům v kalendářním roce 2014, zatímco vzhledem k přestupnému dni roku 2020 budou jeho dalších 10 měsíců odpovídat kalendářnímu roku 2015.

Navíc:

  • rok 2005 byl a běžný rok začínající v sobotu: jeho první 2 měsíce odpovídaly, kromě 29. února, měsícům kalendářního roku 2000 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 1994. Samozřejmě, protože ani rok 1994, ani rok 2005 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2006 byl a běžný rok začínající v neděli: jeho první 2 měsíce odpovídaly měsícům kalendářního roku 1995 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2000. Samozřejmě, protože ani rok 1995, ani rok 2006 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2007 byl a běžný rok začínající v pondělí: rok jako celek odpovídal kalendářnímu roku 2001.
  • rok 2008 byl a přestupný rok začínající v úterý: jeho první 2 měsíce, s výjimkou 29. února, odpovídaly měsícům kalendářního roku 2002 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2003. Rok jako celek bude odpovídat kalendářnímu roku 1980. 29. února byl pátek.
  • rok 2009 byl a běžný rok začínající ve čtvrtek: jeho první 2 měsíce odpovídaly, kromě 29. února, měsícům kalendářního roku 2004 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 1998. Samozřejmě, protože ani rok 1998, ani rok 2009 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2010 byl a běžný rok začínající v pátek: jeho první 2 měsíce odpovídaly měsícům kalendářního roku 1999 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2004. Samozřejmě, protože ani rok 1999, ani rok 2010 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2011 byl a běžný rok začínající v sobotu: rok jako celek odpovídal kalendářnímu roku 2005.
  • rok 2012 byl a přestupný rok začínající v neděli: jeho první 2 měsíce, s výjimkou 29. února, odpovídaly měsícům kalendářního roku 2006 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2007. Rok jako celek bude odpovídat kalendářnímu roku 1984. 29. února byla středa.
  • rok 2013 byl a běžný rok začínající v úterý: jeho první 2 měsíce odpovídaly, kromě 29. února, měsícům kalendářního roku 2008 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2002. Samozřejmě, protože ani rok 2002, ani rok 2013 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2014 byl a běžný rok začínající ve středu: jeho první 2 měsíce odpovídaly měsícům kalendářního roku 2003 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2008. Samozřejmě, protože ani rok 2003, ani rok 2014 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2015 byl a běžný rok začínající ve čtvrtek: rok jako celek odpovídal kalendářnímu roku 2009.
  • rok 2016 byl a přestupný rok začínající v pátek: jeho první 2 měsíce, s výjimkou 29. února, odpovídaly měsícům kalendářního roku 2010 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2011. Rok jako celek bude odpovídat kalendářnímu roku 1988. 29. února bylo pondělí.
  • rok 2017 byl a běžný rok začínající v neděli: jeho první 2 měsíce odpovídaly, kromě 29. února, měsícům kalendářního roku 2012 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2006. Samozřejmě, protože ani rok 2006, ani rok 2017 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2018 byl a běžný rok začínající v pondělí: jeho první 2 měsíce odpovídaly měsícům kalendářního roku 2007 a jeho dalších 10 měsíců odpovídalo kalendářnímu roku 2012. Samozřejmě, protože ani rok 2007, ani rok 2018 nebyl přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2019 byl a běžný rok začínající v úterý: rok jako celek odpovídal kalendářnímu roku 2013.
  • rok 2020 je přestupný rok začínající ve středu: jeho první 2 měsíce, s výjimkou 29. února, budou odpovídat měsícům kalendářního roku 2014 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2015. Rok jako celek bude odpovídat kalendářnímu roku 1992. 29. února bude sobota.
  • rok 2021 bude běžný rok začínající v pátek: jeho první 2 měsíce budou kromě 29. února odpovídat kalendářním rokům 2016 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2010. Samozřejmě, protože ani rok 2010, ani rok 2021 není přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2022 bude běžný rok začínající v sobotu: jeho první 2 měsíce budou odpovídat měsícům kalendářního roku 2011 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2016. Samozřejmě, protože ani rok 2011, ani rok 2022 nejsou přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2023 bude běžný rok začínající v neděli: rok jako celek bude odpovídat kalendářnímu roku 2017.
  • rok 2024 bude přestupný rok začínající v pondělí: jeho první 2 měsíce, s výjimkou 29. února, budou odpovídat měsícům kalendářního roku 2018 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2019. Rok jako celek bude odpovídat kalendářnímu roku 1996. 29. února bude čtvrtek.
  • rok 2025 bude běžný rok začínající ve středu: jeho první dva měsíce budou odpovídat měsícům v kalendářním roce 2020 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2014. Samozřejmě, protože ani rok 2014, ani rok 2025 nejsou přestupným rokem, tyto dva roky zcela odpovídají.
  • rok 2026 bude běžný rok začínající ve čtvrtek: jeho první dva měsíce budou odpovídat měsícům v kalendářním roce 2015 a jeho dalších 10 měsíců bude odpovídat měsícům v kalendářním roce 2020. Samozřejmě, protože ani rok 2015, ani rok 2026 není přestupným rokem, tyto dva roky odpovídají celistvosti.
  • rok 2027 bude běžný rok začínající v pátek: rok jako celek bude odpovídat kalendářnímu roku 2021.
  • rok 2028 bude přestupný rok začínající v sobotu: jeho první dva měsíce, s výjimkou 29. února, budou odpovídat měsícům kalendářního roku 2022 a jeho dalších 10 měsíců bude odpovídat měsícům v kalendářním roce 2023. Rok jako celek bude odpovídat kalendářnímu roku 2000. 29. února bude úterý. Jako vedlejší poznámka jsou přestupné roky začínající v sobotu jediným typem přestupného roku, kterým může začít přestupný rok konce století.
  • rok 2029 bude běžný rok začínající v pondělí: jeho první dva měsíce budou odpovídat měsícům v kalendářním roce 2024 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2018. Samozřejmě, protože ani rok 2018, ani rok 2029 nejsou přestupným rokem, tyto dva roky samozřejmě odpovídají celistvosti.
  • rok 2030 bude běžný rok začínající v úterý: jeho první dva měsíce budou odpovídat měsícům v kalendářním roce 2019 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2024. Samozřejmě, protože ani rok 2019, ani rok 2030 nejsou přestupným rokem, tyto dva roky neodpovídají v plném rozsahu.
  • rok 2031 bude běžný rok začínající ve středu: rok jako celek bude odpovídat kalendářnímu roku 2025.
  • rok 2032 bude přestupný rok začínající ve čtvrtek: jeho první dva měsíce budou odpovídat kalendářnímu roku 2026 a jeho dalších 10 měsíců bude odpovídat kalendářnímu roku 2027. Rok jako celek bude odpovídat kalendářnímu roku 2004. 29. února bude neděle.

Podrobnosti viz tabulka níže.

Rok
století mod 28
y
00 06 12 17 230
01 07 12 18 241
02 08 13 19 242
03 08 14 20 253
04 09 15 20 264
04 10 16 21 275
05 11 16 22 006

Poznámky:

  • Černá znamená všechny měsíce běžného roku
  • Červené znamená první 2 měsíce přestupného roku
  • Modrý znamená posledních 10 měsíců přestupného roku

Odpovídající staletí

Juliánské století
mod 700
Gregoriánské století
mod 400[6]
Den
400: 1100 1800 ...300: 1500 1900 ...slunce
300: 1000 1700 ...Pondělí
200 0900 1600 ...200: 1800 2200 ...Út
100 0800 1500 ...St
700: 1400 2100 ...100: 1700 2100 ...Čtvrtek[7]
600: 1300 2000 ...
500: 1200 1900 ...000: 1600 2000 ...So

„Rok 000“ je v normální chronologii rok 1 př. N. L. (Který předchází inzerátu 1). v číslování astronomického roku rok 0 je mezi 1 př. n. l. a 1. nl proleptický juliánský kalendář, (tj. Juliánský kalendář, jaký by byl, kdyby byl správně provozován od začátku), 1 BC začíná ve čtvrtek. V proleptický gregoriánský kalendář, (tzv. protože to bylo navrženo až v roce 1582), 1 BC začíná v sobotu.

Tabulkové metody pro výpočet dne v týdnu

Kompletní tabulka: juliánské a gregoriánské kalendáře

U juliánských dat před rokem 1300 a po roce 1999 by měl být použit rok v tabulce, který se liší přesným násobkem 700 let. U gregoriánských dat po roce 2299 by měl být použit rok v tabulce, který se liší přesným násobkem 400 let. Hodnoty "r0" přes "r6"uveďte zbytek, když je hodnota Stovky vydělena 7 a 4, což znamená, jak se řada rozšiřuje v obou směrech. Hodnoty Julian i Gregorian jsou pro pohodlí zobrazeny od 1500 do 1999. Tučná čísla (např. 04) označují přestupný rok. Pokud rok končí v 00 a jeho stovky jsou tučně, jedná se o přestupný rok. 19 tedy naznačuje, že rok 1900 není gregoriánským přestupným rokem, (ale 19 ve sloupci Julian to naznačuje je Julian přestupný rok, stejně jako všichni Julian X00 let). 20 naznačuje, že rok 2000 je přestupným rokem. Použití Jan a Února pouze v přestupných letech.

Stovky letZbývající číslice rokuMěsícD
Ó
Ž
#
Juliane
(r ÷ 7)
gregoriánský
(r ÷ 4)
r5 1916 20 r000 06   17 2328 34   45 5156 62   73 7984 90JanŘíjnaSa0
r4 1815 19 r301 07 12 1829 35 40 4657 63 68 7485 91 96SmětNe1
r3 17
N / A
02   13 19 2430   41 47 5258   69 75 8086   97ÚnoraSrpenM2
r2 1618 22 r203 08 14   2531 36 42   5359 64 70   8187 92 98ÚnoraMarlistopadTu3
R1 15
N / A
  09 15 20 26  37 43 48 54  65 71 76 82  93 99ČervnaŽ4
r0 1417 21 R104 10   21 2732 38   49 5560 66   77 8388 94ZáříProsinecČt5
r6 13
N / A
05 11 16 2233 39 44 5061 67 72 7889 95JanDubnaJulF6

Pro určení dne v týdnu (1. ledna 2000, sobota)

  • den v měsíci: 1 ~ 31 (1)
  • měsíc: (6)
  • rok: (0)
  • století mod 4 pro gregoriánský kalendář a mod 7 pro juliánský kalendář (0).
  • přidání 1 + 6 + 0 + 0 = 7. Dělení 7 ponechává zbytek 0, takže dnem v týdnu je sobota.

Vzorec je w = (d + m + y + c) mod 7.

Revidovaný juliánský kalendář

Všimněte si, že datum (a tedy den v týdnu) v revidovaných juliánských a gregoriánských kalendářích je stejné od 14. října 1923 do 28. února roku 2800 včetně a že u velkých let bude možné odečíst 6300 nebo jejich násobek před počínaje tak, aby dosáhl roku, který je uvnitř nebo blíže ke stolu.

Chcete-li pomocí tabulky vyhledat všední den libovolného data pro libovolný rok, odečtěte od roku 100, vydělte rozdíl 100, výsledný kvocient (vynechejte zlomky) vynásobte sedmi a produkt vydělte devíti. Všimněte si kvocientu (vynechání zlomků). Vstupte do tabulky s juliánským rokem a těsně před závěrečným dělením přidejte 50 a odečtěte kvocient uvedený výše.

Příklad: Jaký je den v týdnu od 27. ledna 8315?

8315-6300 = 2015, 2015-100 = 1915, 1915/100 = 19 zbytek 15, 19x7 = 133, 133/9 = 14 zbytek 7. 2015 je o 700 let před rokem 1315, takže se používá 1315. Z tabulky: pro stovky (13): 6. Pro zbývající číslice (15): 4. Pro měsíc (leden): 0. Pro datum (27): 27. 6 + 4 + 0 + 27 + 50-14 = 73. 73/7 = 10 zbývajících 3. den v týdnu = úterý.

Dominikální dopis

Chcete-li najít Dominikální dopis, vypočítat den v týdnu buď 1. ledna, nebo 1. října. Pokud je neděle, nedělní písmeno je A, pokud sobota B, a podobně zpět přes týden a vpřed přes abecedu do pondělí, což je G.

Přestupné roky mají dvě nedělní písmena, takže pro leden a únor vypočítejte den v týdnu pro 1. leden a pro březen až prosinec vypočítejte den v týdnu pro 1. říjen.

Přestupné roky jsou všechny roky, které se dělí přesně čtyřmi, s následujícími výjimkami:

V gregoriánském kalendáři - všechny roky, které se dělí přesně 100 (jiné než ty, které dělí přesně 400).

V revidovaném juliánském kalendáři - všechny roky, které se dělí přesně 100 (jiné než ty, které dávají zbytek 200 nebo 600 po dělení 900).

„Soudný den“

Toto je artefakt rekreační matematiky. Vidět pravidlo soudného dne pro vysvětlení.

Zkontrolujte výsledek

Tuto tabulku použijte k vyhledání dne v týdnu bez jakýchkoli výpočtů.

IndexPondělí
A
Út
B
St
C
Čtvrtek
D

E
So
F
slunce
G
Věčný gregoriánský a juliánský kalendář
Použití Jan a Února pro přestupné roky
Datum písmeno v řádku roku pro písmeno v řádku století

Všechny dny C jsou doomsdays

Juliane
století
gregoriánský
století
datum01
08
15
22
29
02
09
16
23
30
03
10
17
24
31
04
11
18
25

05
12
19
26

06
13
20
27

07
14
21
28

12 1916 20DubnaJulJanGABCDEF010712182935404657636874859196
13 20ZáříProsinecFGABCDE0213192430414752586975808697
14 2117 21ČervnaEFGABCD030814253136425359647081879298
15 22ÚnoraMarlistopadDEFGABC0915202637434854657176829399
16 2318 22SrpenÚnoraCDEFGAB0410212732384955606677838894
17 24SmětBCDEFGA0511162233394450616772788995
18 2519 23JanŘíjnaABCDEFG0617232834455156627379849000
[Rok / 100]gregoriánský
století
20
16
21
17
22
18
23
19
Rok mod 100
Juliane
století
19
12
20
13
21
14
22
15
23
16
24
17
25
18

Příklady:

  • Pro běžnou metodu
26. prosince 1893 (GD)

Prosinec je v řadě F a 26 je ve sloupci E, takže písmeno pro datum je C umístěné v řádku F a sloupec E. 93 (rok mod 100) je v řadě D (řádek roku) a písmeno C v řádku roku se nachází ve sloupci G. 18 ([year / 100] in the Gregorian century column) is in row C (řádek století) a písmeno v řádku a sloupci století G je B, takže dnem v týdnu je úterý.

13. října 1307 (JD)

13. října je den F. Písmeno F v řádku roku (07) se nachází ve sloupci G. Písmeno v řádku (13) a sloupci století G je E, takže dnem v týdnu je pátek.

1. ledna 2000 (GD)

1. leden odpovídá G, G v řádku roku (00) odpovídá F v řadě století (20) a F odpovídá sobotě.

Stručný vzorec pro metodu: „Datum písmeno (G), písmeno (G) je v řádku roku (00) pro písmeno (F) v řádce století (20) a pro den se písmeno (F) stává všedním dnem (sobota) ".

Metoda nedělního dopisu

Každý den v roce (kromě 29. února) má přiděleno písmeno v opakující se posloupnosti ABCDEFG. Série začíná písmenem A 1. ledna a pokračuje písmenem A 31. prosince. Nedělní dopis je ten, který stojí proti všem nedělám v roce. Protože 29. února nemá žádný dopis, znamená to, že nedělní dopis pro březen až prosinec je o krok zpět v pořadí ve srovnání s lednovým a únorovým. Písmeno pro jakékoli datum najdete tam, kde se řádek obsahující měsíc (černě) vlevo od „latinského čtverce“ setkává se sloupcem obsahujícím datum nad „latinským čtvercem“. Nedělní písmeno najdete tam, kde se sloupec obsahující století (pod „latinským čtvercem“) setkává s řádkem obsahujícím poslední dvě číslice roku napravo od „latinského čtverce“. Pro přestupný rok je takto nalezený nedělní dopis ten, který platí pro březen až prosinec.

Například pro zjištění pracovního dne 16. června 2020:

Sloupec „20“ odpovídá řádku „20“ v „D“. Řádek „Červen“ odpovídá sloupci „16“ v „F“. Jelikož F jsou dvě písmena od D, je všední den dva dny od neděle, tj. Úterý.

Matematické algoritmy

Gaussův algoritmus

V ručně psané poznámce ve sbírce astronomických tabulek, Carl Friedrich Gauss popsal metodu výpočtu dne v týdnu k 1. lednu v daném roce.[8] Nikdy to nezveřejnil. To bylo nakonec zahrnuto do jeho sebraných děl v roce 1927.[9]

Gaussova metoda byla použitelná pro gregoriánský kalendář. Počítal pracovní dny od 0 do 6, počínaje nedělí. Definoval následující operaci: Den v týdnu 1. ledna v čísle roku A je[8]

nebo

ze kterého lze odvodit metodu pro juliánský kalendář

nebo

kde je zbytek po rozdělení y podle m,[9] nebo y modulo m, a Y + 100C = A.

Pro rok číslo 2000, A - 1 = 1999, Y - 1 = 99 a C = 19, den v týdnu 1. ledna je

Den v týdnu posledního dne v čísle roku A - číslo 1 nebo 0 ledna v roce A je

Den v týdnu 0 (běžný rok) nebo 1 (přestupný rok) leden v čísle roku A je

Abychom mohli určit den v týdnu libovolného data, použijeme následující vyhledávací tabulku.

Měsíce11
Jan
12
Února
1
Mar
2
Dubna
3
Smět
4
Června
5
Jul
6
Srpen
7
Září
8
Října
9
listopad
10
Prosinec
M
Běžné roky033614625035m
Přestupné roky4025036146
Algoritmus

Poznámka: minus 1, pokud M je 11 nebo 12 a plus 1, pokud M méně než 11 v přestupném roce.

Den v týdnu pro kterýkoli den v roce číslo A je

nebo

kde D je den v měsíci a A - 1 za leden nebo únor

Pracovní dny pro 30. dubna 1777 a 23. února 1855 jsou

a

Tento vzorec také převedli Kraitchik a Schwerdtfeger do grafických a tabulkových metod pro výpočet kteréhokoli dne v týdnu.[9][10]

Nesourodá variace

Další variace výše uvedeného algoritmu funguje také bez vyhledávacích tabulek. Mírnou nevýhodou je neobvyklá konvence počítání měsíců a roků. Vzorec je

kde

  • Y je rok minus 1 pro leden nebo únor a rok pro jakýkoli jiný měsíc
  • y jsou poslední 2 číslice Y
  • C jsou první 2 číslice Y
  • d je den v měsíci (1 až 31)
  • m je posunutý měsíc (březen = 1, ..., únor = 12)
  • w je den v týdnu (0 = neděle, ..., 6 = sobota). Pokud je w záporné, musíte k němu přidat 7.

Například 1. ledna 2000. (rok - 1 pro leden)

Poznámka: První je pouze pro přestupný rok 00 a druhý pro všech 00 let.

Termín udává hodnoty měsíců: m

Měsícem
leden0
Únor3
březen2
duben5
Smět0
červen3
červenec5
srpen1
září4
říjen6
listopad2
prosinec4

Termín udává hodnoty let: y

y mod 28y
01 07 12 18 --1
02-13 19 242
03 08 14-253
-- 09 15 20 264
04 10-21 275
05 11 16 22 --6
06-17 23 000

Termín dává hodnoty staletí: C

C mod 4C
15
23
31
00

Nyní z obecného vzorce: ; 1. ledna 2000 lze přepočítat takto:

Zellerův algoritmus

V Zellerově algoritmu jsou měsíce počítány od 3 za březen do 14 za únor. Předpokládá se, že rok začne v březnu; to například znamená, že s lednem 1995 se má zacházet jako s 13. měsícem roku 1994.[11] Vzorec pro gregoriánský kalendář je

kde

  • Y je rok minus 1 pro leden nebo únor a rok pro jakýkoli jiný měsíc
  • y je poslední 2 číslice z Y
  • C je první 2 číslice z Y
  • d je den v měsíci (1 až 31)
  • m je posunutý měsíc (březen = 3, ... leden = 13, únor = 14)
  • w je den v týdnu (1 = neděle, .. 0 = sobota)

Jediný rozdíl je mezi Zellerovým algoritmem (Z) a Gaussův algoritmus (G), to je Z - G = 1 = neděle.

(Březen = 3 palce Z ale March = 1 in G)

Můžeme tedy získat hodnoty měsíců od hodnot pro Gaussův algoritmus přidáním jedné:

Měsícem
leden1
Únor4
březen3
duben6
Smět1
červen4
červenec6
srpen2
září5
říjen0
listopad3
prosinec5

Wangův algoritmus

Wangův algoritmus [12] pro gregoriánský kalendář je (vzorec by měl být odečten o 1, pokud m je 1 nebo 2 a rok je přestupný rok)

kde

  • je poslední číslice roku
  • je poslední druhá číslice roku
  • jsou první 2 číslice roku
  • je den v měsíci (1 až 31)
  • je měsíc (leden = 1, ... prosinec = 12)
  • je den v týdnu (0 = neděle, ... 6 = sobota)
  • je funkce null-days s hodnotami uvedenými v následující tabulce
m
11Den
35m + 2
57
79
93m + 1
1112
212m + 3
42m - 2
64
86
108
1210

Algoritmus pro juliánský kalendář lze odvodit z výše uvedeného algoritmu

kde je soudný den.

m
13Den C.
37m + 4
59
711
95m - 4
117
20m - 2
44m
66
88
1010
1212

Další algoritmy

Schwerdtfegerova metoda

V částečně tabulkové metodě Schwerdtfegera je rok rozdělen na století a dvouciferný rok v rámci století. Přístup závisí na měsíci. Pro m ≥ 3,

tak G je mezi 0 a 99. Pro m = 1,2,

Vzorec pro den v týdnu je[9]

kde je zvolen kladný modul.[9]

Hodnota E je získán z následující tabulky:

m123456789101112
E032503514624

Hodnota F je získán z následující tabulky, která závisí na kalendáři. Pro gregoriánský kalendář[9]

C mod 40123
F0531

Pro juliánský kalendář[9]

C mod 70123456
F5432106

Metoda Lewise Carrolla

Charles Lutwidge Dodgson (Lewis Carroll ) vymyslel metodu připomínající hádanku, přesto částečně tabulkově používající stejná čísla indexů pro měsíce jako v „Kompletní tabulce: Juliánské a Gregoriánské kalendáře“ výše. Uvádí stejné tři úpravy pro první tři měsíce nepřestupných let, jednu o 7 výše pro poslední a dává záhadné pokyny k nalezení zbytku; jeho úpravy po staletí budou stanoveny pomocí vzorců podobných těm, které jsou uvedeny v tabulce století. Ačkoli výslovně tvrdí, že jeho metoda také funguje Starý styl data, jeho příklad je uveden níže, aby určil, že „1676, 23. února“ je středa, funguje pouze na juliánský kalendář, který začíná rok 1. ledna, místo 25. března jako na „starém stylu“ Juliánský kalendář.

Algoritmus:[13]

Vezměte dané datum ve 4 porcích, viz. počet století, počet let, měsíc, den v měsíci.

Vypočítejte následující 4 položky a přidejte každou, je-li nalezena, k součtu předchozích položek. Pokud položka nebo součet přesáhne 7, vydělte 7 a ponechejte pouze zbytek.

Položka století: Pro 'Starý styl „(které skončilo 2. září 1752) odečíst od 18. pro“Nový styl „(která začala 14. září 1752) vydělit 4, převzít přebytek od 3, zbytek vynásobit 2.

Položka roku: Sečtěte počet desítek, přebytek a počet 4 s v přebytku.

Měsíční položka: Pokud začíná nebo končí samohláskou, odečtěte číslo, označující jeho místo v roce, od 10. To plus jeho počet dní dává položku pro následující měsíc. Položka pro leden je „0“; pro únor nebo březen „3“; na prosinec „12“.

Denní položka: Takto dosažený součet musí být opraven odečtením „1“ (první přidání 7, je-li součet „0“), pokud je datem leden nebo únor v přestupném roce, pamatujeme na to každý rok, dělitelný 4, je přestupný rok, s výjimkou století, v „novém stylu“, kdy počet století není tak dělitelný (např. 1 800).

Konečný výsledek udává den v týdnu, „0“ znamená neděli, „1“ pondělí atd.

Příklady:[13]

1783, 18. září

17, děleno 4, ponechává „1“ nad; 1 ze 3 dává „2“; dvakrát 2 je „4“. 83 je 6 tuctů a 11, což dává 17; plus 2 dává 19, tj. (děleno 7) „5“. Celkem 9, tj. „2“ Položka za srpen je „8 z 10“, tj. „2“; pro září je to tedy „2 plus 31“, tj. „5“, celkem 7, tj. „0“, které zhasne. 18 dává „4“. Odpověď: „Čtvrtek“.

1676, 23. února

16 z 18 dává „2“ 76 je 6 tucet a 4, což dává 10; plus 1 dává 11, tj. „4“. Celkem „6“ Položka za únor je „3“. Celkem 9, tj. „2“ 23 dává „2“. Celková oprava „4“ pro přestupný rok dává „3“. Odpověď, „středa“.

Protože 23. února 1676 (počítá se únor jako druhý měsíc) je pro Carrolla stejný den jako gregoriánský 4. března 1676, nedaří se mu najít správnou odpověď, konkrétně „pátek“ pro datum ve starém stylu, které je v gregoriánském kalendáři je stejný den jako 5. března 1677. Kdyby správně předpokládal, že rok začne 25. března, jeho metoda by odpovídala za různá čísla let - přesně jako George Washington narozeniny se liší - mezi těmito dvěma kalendáři.

Je pozoruhodné, že ti, kteří znovu publikovali Carrollovu metodu, nedokázali poukázat na jeho chybu, zejména Martin Gardner.[14]

V roce 1752 britské impérium upustilo od používání Starý styl Juliánský kalendář po přijetí Gregoriánský kalendář, který se stal dnešním standardem ve většině zemí světa. Další pozadí viz Data starého a nového stylu.

Metody závislé na implementaci

V Jazyk C. výrazy níže, y, m a d jsou celočíselné proměnné představující rok (např. 1988), měsíc (1-12) a den měsíce (1-31).

        (d + = m <3? y -: y-2,23 * m / 9 + d + 4 + y / 4-y / 100 + y / 400)% 7 

V roce 1990 zveřejnili Michael Keith a Tom Craver výše uvedený výraz, který se snaží minimalizovat počet stisků kláves potřebných k zadání samostatné funkce pro převod gregoriánského data na numerický den v týdnu.[15] Nezachovává ani jeden y ani da vrátí se 0 = Neděle, 1 = Pondělí atd.

Krátce nato Hans Lachman zjednodušil svůj algoritmus pro snadné použití na zařízeních nižší třídy. Jak bylo původně navrženo pro čtyřfunkční kalkulačky, jeho metoda potřebuje méně položek na klávesnici tím, že omezí její rozsah buď na roky 1905–2099 n. L., Nebo na historická juliánská data. Později byl upraven pro převod libovolného gregoriánského data, dokonce i na počitadlo. Na Motorola 68000 -založené zařízení, tam je podobně menší potřeba obou registry procesorů nebo opcodes, v závislosti na zamýšleném účelu návrhu.[16]

Sakamotovy metody

Tabulkový předchůdce Tønderingova algoritmu je ztělesněn v následujícím textu K&R C. funkce.[17] S menšími změnami byl upraven pro ostatní programovací jazyky na vysoké úrovni jako APL2.[18] Zveřejnil Tomohiko Sakamoto na webu comp.lang.c Diskusní skupina Usenet v roce 1992 je přesný pro jakékoli gregoriánské datum.[19][20]

    dayofweek (y, m, d) / * 1 <= m <= 12, y> 1752 (ve Velké Británii) * / {static int t [] = {0, 3, 2, 5, 0, 3, 5, 1, 4, 6, 2, 4}; y - = m <3; výnos (y + y / 4 - y / 100 + y / 400 + t [m-1] + d)% 7; }

Funkce se ne vždy zachová ya vrátí se 0 = Neděle, 1 = Pondělí atd. Naproti tomu následující výraz

    dow (m, d, y) {y- = m <3; zpáteční (y + y / 4-y / 100 + y / 400 + "- postel = pero + mad." [m] + d)% 7; }

zveřejněno současně Sakamotem není snadno přizpůsobitelné jiným jazykům a může dokonce selhat, pokud je kompilováno v počítači, který kóduje znaky pomocí jiného než standardního ASCII hodnoty (např. EBCDIC ), nebo na kompilátorech C, které vynucují ANSI C. dodržování předpisů (i u kódu, který je stále kompatibilní s originálem K&R C. specifikace, pokud je vynechána prohlášení typu jsou považovány za celé číslo). Pouze pro druhou úvahu lze Sakamotovu podrobnější verzi považovat zapřenosný stejně jako Keith a Craver.

Rata Die

IBM je Rata Die metoda vyžaduje, aby člověk poznal "klíčový den" proleptický gregoriánský kalendář tj. den v týdnu 1. ledna AD 1 (jeho první datum). To je třeba udělat pro stanovení zbývajícího počtu, na jehož základě je pro druhou část analýzy stanoven den v týdnu. Použitím daného dne 13. Srpna 2009, který byl čtvrtek jako reference, s Základna a n je počet dní a týdnů od 1. 1. 2001 do daného dne, resp k den do daného týdne, který musí být méně než 7, Základna je vyjádřena jako

                      Základna = 7n + k       (i)

S vědomím, že rok dělitelný 4 nebo 400 je přestupným rokem, zatímco rok dělitelný 100 a ne 400 není přestupným rokem, lze napsat softwarový program a zjistit počet dní. Následuje překlad metody C provedené společností IBM do jazyka C. REXX programovací jazyk.

int daystotal (int y, int m, int d) {static char daytab [2] [13] = {{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 }, {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}}; int daystotal = d; for (int year = 1; year <= y; year ++) {int max_month = (year 

Je zjištěno, že denní is 733632 from the base date January 1, AD 1. This total number of days can be verified with a simple calculation: There are already 2008 full years since 01/01/0001. The total number of days in 2008 years not counting the leap days is 365 *2008 = 732920 days. Assume that all years divisible by 4 are leap years. Add 2008/4 = 502 to the total; then subtract the 15 leap days because the years which are exactly divisible by 100 but not 400 are not leap. Continue by adding to the new total the number of days in the first seven months of 2009 that have already passed which are 31 + 28 + 31 + 30 + 31 + 30 + 31 = 212 days and the 13 days of August to get Základna = 732920 + 502 - 20 + 5 + 212 + 13 = 733632.

What this means is that it has been 733632 days since the base date. Substitute the value of Základna into the above equation (i) to get 733632 = 7 *104804 + 4, n = 104804 and k = 4 which implies that August 13, 2009 is the fourth day into the 104805th week since 01/01/0001. 13 August 2009 is Thursday; therefore, the first day of the week must be Monday, and it is concluded that the first day 01/01/0001 of the calendar is pondělí. Based on this, the remainder of the ratio Base/7, defined above as k, decides what day of the week it is. Li k = 0, it's Monday, k = 1, it's Tuesday, etc.[21]

Viz také

Reference

  1. ^ To explain this in detail, visualise a calendar hanging on the wall depicting a month beginning on Sunday (e.g. March 2020). You will see that the 1st is a Sunday. Now count forward seven days. This brings you to the 8th, which is also a Sunday. Count forward ten days. This brings you to the 18th, which is a Wednesday. Now the 4th is a Wednesday (being three days after Sunday 1st). Count forward seven days. This brings you to Wednesday 11th, three days after Sunday 8th. Count forward another seven days. This brings you to Wednesday 18th, three days after Sunday 15th, which falls two weeks after Sunday 1st.
  2. ^ A b Brothers, Hardin; Rawson, Tom; Conn, Rex C.; Paul, Matthias R .; Dye, Charles E .; Georgiev, Luchezar I. (2002-02-27). Online nápověda 4DOS 8.00.
  3. ^ "HP Prime - Portal: Firmware update" (v němčině). Moravia Education. 2015-05-15. Archivováno od originálu 2016-11-05. Citováno 2015-08-28.
  4. ^ Paul, Matthias R. (1997-07-30). NWDOS-TIPs - Tipy a triky, rund um Novell DOS 7, s Blick auf undokumentierte Podrobnosti, Bugs and Workarounds. MPDOSTIP. Release 157 (in German) (3rd ed.). Archivováno z původního dne 2016-11-04. Citováno 2014-08-06. (Pozn. NWDOSTIP.TXT je komplexní práce na Novell DOS 7 a OpenDOS 7.01, including the description of many undocumented features and internals. It is part of the author's yet larger MPDOSTIP.ZIP collection maintained up to 2001 and distributed on many sites at the time. The provided link points to a HTML-converted older version of the NWDOSTIP.TXT file.)
  5. ^ Richards, E. G. (1999). Mapování času: kalendář a jeho historie. Oxford University Press.
  6. ^ The numbers in the first column are proleptic - the Gregorian calendar was not devised till 1582. See the note beneath the table.
  7. ^ The Julian century beginning 1 BC would also appear on this line of the table (to the left of 700) but there is no space to include it.
  8. ^ A b Gauss, Carl F. (1981). "Den Wochentag des 1. Januar eines Jahres zu finden. Gueldene Zahl. Epakte. Ostergrenze.". Werke. herausgegeben von der Koeniglichen Gesellschaft der Wissenschaften zu Goettingen (2. vyd.). Hildesheim: Georg Olms Verlag. 206–207. ISBN  978-3-48704643-3.
  9. ^ A b C d E F G Schwerdtfeger, Berndt E. (2010-05-07). "Gauss' calendar formula for the day of the week" (PDF) (1.4.26 ed.). Citováno 2012-12-23.
  10. ^ Kraitchik, Maurice (1942). "Chapter 5: The calendar". Mathematical recreations (2nd revised [Dover] ed.). Mineola: Dover Publications. pp. 109–116. ISBN  978-0-48645358-3.
  11. ^ Stockton, J. R. (2010-03-19). "The Calendrical Works of Rektor Chr. Zeller: The Day-of-Week and Easter Formulae". Merlyn. Citováno 2012-12-19.
  12. ^ Wang, Xiang-Sheng (March 2015). "Calculating the day of the week: null-days algorithm" (PDF). Rekreační matematický časopis. Č. 3. str. 5.
  13. ^ A b Dodgson, C.L. (Lewis Carroll ). (1887). "To find the day of the week for any given date". Příroda, 31 March 1887. Reprinted in Mapping Time, pp. 299-301.
  14. ^ Martin Gardner. (1996). The Universe in a Handkerchief: Lewis Carroll's Mathematical Recreations, Games, Puzzles, and Word Plays, pages 24-26. Springer-Verlag.
  15. ^ Michael Keith; Tom Craver. (1990). The ultimate perpetual calendar? Journal of Recreational Mathematics, 22:4, pp.280-282.
  16. ^ The 4-function Calculator; The Assembly of Motorola 68000 Orphans; The Abacus. gopher://sdf.org/1/users/retroburrowers/TemporalRetrology
  17. ^ "Day-of-week algorithm NEEDED!" news:[email protected]
  18. ^ APL2 IDIOMS workspace: Date and Time Algorithms, line 15. ftp://ftp.software.ibm.com/ps/products/apl2/info/APL2IDIOMS.pdf (2002)
  19. ^ Google newsgroups:comp.lang.c. (Prosinec 1992). "Date -> Day of week conversion". Citováno 2020-06-21.
  20. ^ Google newsgroups:comp.lang.c. (1994). "DOW algorithm". Citováno 2020-06-21.
  21. ^ REXX/400 Reference manual page 87 (1997).
  • Hale-Evans, Ron (2006). "Hack #43: Calculate any weekday". Mind performance hacks (1. vyd.). Peking: O'Reilly. str.164–169. ISBN  9780596101534.
  • Thioux, Marc; Stark, David E.; Klaiman, Cheryl; Schultz, Robert T. (2006). "The day of the week when you were born in 700 ms: Calendar computation in an autistic savant". Journal of Experimental Psychology: Human Perception and Performance. 32 (5): 1155–1168. doi:10.1037/0096-1523.32.5.1155.
  • Treffert, Darold A. "Why calendar calculating?". Islands of genius : the bountiful mind of the autistic, acquired, and sudden savant (1. publ., [repr.]. ed.). Londýn: Jessica Kingsley. str. 63–66. ISBN  9781849058735.

externí odkazy