Codegolf/3
Jump to navigation
Jump to search
Challenge #3: Wochentagberechnung
"Wie ist der Wochentag eines bestimmten Datums?"
$ ./wochentag 1. Januar 1970 Donnerstag $
Siehe: http://de.wikipedia.org/wiki/Wochentagsberechnung
Um es ein wenig golfbarer zu machen, rechnen wir nur mit dem
gregorianischen Kalender.
Man kann davon ausgehen, dass das Programm immer mit einem legitimen Datum aufgerufen wird. Der Aufruf ist immer in der Form
\d+\. (Januar|Februar|März|April|Mai|Juni|Juli|August|September|Oktober|November|Dezember) \d+
Die Ausgabe muss:
(Montag|Dienstag|Mittwoch|Donnerstag|Freitag|Samstag|Sonntag)\n
entsprechen.
sur5r ist der Schiedsrichter dieser Challenge.
Es dürfen keine generischen/speziellen Datumsumrechnungsmodule der Sprache benutzt werden, auch wenn sie Bestandteil der Distribution der Sprache sind.
Das Programm darf nichts nach STDERR schreiben
Test
#!/usr/bin/ruby def assert_eq(a, b) raise Exception.new("assertion failed: "+a+"!="+b) if a!=b end assert_eq `#{ARGV[0]} 14. Juli 1789`, "Dienstag\n" assert_eq `#{ARGV[0]} 23. Mai 1949`, "Montag\n" assert_eq `#{ARGV[0]} 20. März 1983`, "Sonntag\n" assert_eq `#{ARGV[0]} 9. November 1989`, "Donnerstag\n" assert_eq `#{ARGV[0]} 12. Januar 2006`, "Donnerstag\n" assert_eq `#{ARGV[0]} 1. Januar 2000`, "Samstag\n" assert_eq `#{ARGV[0]} 1. März 2000`, "Mittwoch\n"
./test.rb ./wochentag
Der Test ist genau dann erfolgreich, wenn keinerlei Ausgabe erfolgt.
Inoffizielle, vom Schiri nicht bestätigte Scores
- sECuRE / C: 282 byte (normal), 250 byte (obfuscated, ohne compileraufruf), 161 byte (obfuscated, nicht rules-compliant, ohne compileraufruf)
- mxf / Perl: 190
- downhill / Perl: ???
- PhilFry / Ruby: 244
- $du