mborm.net

Ein Computerprogramm tut was Du schreibst, nicht was Du willst.

Problem 6 auf projecteuler.net

Als ich heute Langeweile hatte, habe ich einmal die Lösung für das Problem 6 in Bash geschrieben, weil ich ohnehin schon den ganzen Tag an verschiedenen Bash-Skripten saß. Das Ergebnis für das Problem 6 berechnet sich sehr schnell:


25164150

real 0m0.002s
user 0m0.000s
sys 0m0.002s

Der Code schaut so aus:

Veröffentlicht am 16. Oktober 2015 von admin in Bash, Programmierung, projecteuler

Problem 102 auf projecteuler.net

Hier ist mal wieder eine neue Lösung auf projecteuler.net, dieses Mal für Problem 102.

Als erstes wurden 2 Methoden erstellt. Eine für die Flächenberechnung des Dreiecks (https://en.wikipedia.org/wiki/Triangle#Using_coordinates) und eine, die prüft, ob der Ursprung im Dreieck enthalten ist.

Danach wurde nur noch die Textdatei mit den zufällig generierten Werten eingelesen und entsprechend aufgesplittet sodass das Programm die Daten nutzen kann.

Die Berechnung ging ebenfalls wieder sehr schnell:

Result: 228

real 0m0.161s
user 0m0.231s
sys 0m0.022s

Hier der Code in Java:

Veröffentlicht am 30. August 2015 von admin in Java, Programmierung, projecteuler

Problem 89 auf projecteuler.net

Heute hatte ich mal wieder etwas Zeit ein weiteres Problem auf projecteuler.net zu lösen. Gelöst habe ich dieses Mal Problem 89 in der Programmiersprache Java.

Das Problem ist dank dieser Hilfe sehr einfach: https://projecteuler.net/about=roman_numerals

Man muss also nur „DCCCC“, „LXXXX“, „VIIII“, „CCCC“, „XXXX“ und „IIII“ ersetzen. Danach muss man nur noch die Differenz der Anzahl der Zeichen vor und nach dem Replacen herausfinden.

Das Programm von mir berechnet die Lösung sehr schnell:


Result: 743

real 0m0.163s
user 0m0.170s
sys 0m0.034s

Und so schaut der Code aus:

Veröffentlicht am 18. Juli 2015 von admin in Java, Programmierung, projecteuler

POST-Requests mit Java senden

Ich hatte letztens das Problem, dass ich via Java mehrere POST-Parameter an einen Server senden musste. Dazu fand ich viele Lösungen im Netz, allerdings auch eine Menge, die nicht funktioniert haben. Daher poste ich mal hier meine Lösung, vielleicht kann sie ja mal jemand gebrauchen.

Hier ist die Klasse PostConnection:

Und so kann man die Klasse als Beispiel nutzen:

Veröffentlicht am 28. Juni 2015 von admin in Java, Programmierung

Problem 55 auf projecteuler.net

Dieses Wochenende habe ich mich mal wieder hingesetzt und eine weiteres Problem auf projecteuler.net gelöst.

Gelöst habe ich Problem 55 in der Programmiersprache C.

Kompiliert habe ich mit folgendem Befehl:

gcc -O3 -Wall Problem55.c -lm -o Problem55

Das Ergebnis berechnet sich sehr schnell:

Result: 249
real 0m0.019s
user 0m0.019s
sys 0m0.000s

So schaut der Quellcode des Programms aus:

Veröffentlicht am 14. Juni 2015 von admin in C, Programmierung, projecteuler

Problem 26 auf projecteuler.net

Hier meine erste Python-Lösung auf projecteuler.net für das Problem 26.


Result: 983

real 0m0.246s
user 0m0.241s
sys 0m0.004s

Veröffentlicht am 3. Mai 2015 von admin in Programmierung, projecteuler, Python

Problem 27 auf projecteuler.net

Hier meine Lösung zu Problem 27 auf projecteuler.net in der Programmiersprache Java.

Bei der Lösung habe ich auf brute force gesetzt. Trotzdem berechnet sich das Ergebnis recht schnell:


Result: -59231

real 0m0.316s
user 0m0.325s
sys 0m0.008s

Veröffentlicht am 30. April 2015 von admin in Java, Programmierung, projecteuler

Problem 11 auf projecteuler.net

Die Lösung zu Problem 11 habe ich ebenfalls in PHP umgesetzt.

Meiner Meinung nach war das Schwierigste an der Aufgabe sich in verschiedene Richtungen im Array zu bewegen. Wenn das klappt, berechnet sich die Lösung allerdings sehr schnell:


Result: 70600674

real 0m0.012s
user 0m0.008s
sys 0m0.004s

Veröffentlicht am 28. April 2015 von admin in PHP, Programmierung, projecteuler

Problem 36 auf projecteuler.net

Hier meine Lösung zu Problem 36 auf projecteuler.net

Die Lösung für dieses Problem ließ sich extrem einfach in PHP bauen – und das Ganze läuft innerhalb von ~ 1 Sekunde:


872187
real 0m1.049s
user 0m1.048s
sys 0m0.000s

Veröffentlicht am 28. April 2015 von admin in PHP, Programmierung, projecteuler

Problem 96 auf projecteuler.net

Hier meine Lösung zu Problem 96 auf projecteuler.net.

Für die Lösung des Problems habe ich das Perl-Module „Games::Sudoku::Solver“ benutzt, welches hier heruntergeladen werden kann.

Die schnellste Lösung ist es nicht, aber immerhin löst sie das Problem:


Result: 24702 !

real 0m9.220s
user 0m9.214s
sys 0m0.000s

So schaut die Lösung aus:

Veröffentlicht am 19. April 2015 von admin in Perl, Programmierung, projecteuler

Problem 29 auf projecteuler.net

Die Lösung zu Problem 29 war extrem einfach.

Diese Lösung habe ich in der Skriptsprache Perl erstellt – die Rechengeschwindigkeit ist da allerdings etwas niedriger aber auch nicht schlecht:


real 0m1.817s
user 0m1.812s
sys 0m0.004s

Hier der Code:

Veröffentlicht am 14. April 2015 von admin in Perl, Programmierung, projecteuler

Problem 92 auf projecteuler.net

Hier ist meine Lösung zu Problem 92 auf projecteuler.net. Die Lösung ist mittels der Programmiersprache C umgesetzt und kann mittels des gcc mit diesem Befehl kompiliert werden:


gcc -O3 -Wall Problem92.c -lm -o Problem92

Auf meinem Rechner braucht das Skript nur eine sehr kurze Zeit zum Berechnen:

real 0m0.639s
user 0m0.638s
sys 0m0.000s

Der Code schaut so aus:

Veröffentlicht am 14. April 2015 von admin in C, Programmierung, projecteuler