2017-11-08 17:39:50 +01:00
|
|
|
<?php if(count(get_included_files()) ==1) exit("Direct access not permitted.");
|
|
|
|
|
|
|
|
class Euler
|
|
|
|
{
|
2018-01-03 22:08:56 +01:00
|
|
|
public static function readSingle($a)
|
2017-11-08 17:39:50 +01:00
|
|
|
{
|
2018-01-01 21:07:48 +01:00
|
|
|
$n3p = str_pad($a['number'], 3, '0', STR_PAD_LEFT);
|
|
|
|
$a['number3'] = $n3p;
|
|
|
|
|
2017-11-08 17:39:50 +01:00
|
|
|
$a['rating'] = self::rateTime($a);
|
2018-01-01 21:07:48 +01:00
|
|
|
|
|
|
|
$a['url'] = '/blog/1/Project_Euler_with_Befunge/problem-' . $n3p;
|
2017-12-31 17:53:59 +01:00
|
|
|
$a['canonical'] = "https://www.mikescher.com" . $a['url'];
|
2018-01-01 21:07:48 +01:00
|
|
|
|
2017-12-31 17:53:59 +01:00
|
|
|
$a['is93'] = ($a['width'] <= 80 AND $a['height'] <= 25);
|
2018-01-01 21:07:48 +01:00
|
|
|
|
|
|
|
$a['url_euler'] = 'https://projecteuler.net/problem=' . $n3p;
|
|
|
|
$a['url_raw'] = 'https://raw.githubusercontent.com/Mikescher/Project-Euler_Befunge/master/processed/Euler_Problem-' . $n3p . '.b93';
|
|
|
|
$a['url_github'] = 'https://github.com/Mikescher/Project-Euler_Befunge';
|
|
|
|
|
|
|
|
$a['file_description'] = (__DIR__ . '/../statics/euler/Euler_Problem-'.$n3p.'_description.md');
|
|
|
|
$a['file_code'] = (__DIR__ . '/../statics/euler/Euler_Problem-'.$n3p.'.b93');
|
|
|
|
$a['file_explanation'] = (__DIR__ . '/../statics/euler/Euler_Problem-'.$n3p.'_explanation.md');
|
|
|
|
|
2017-11-08 17:39:50 +01:00
|
|
|
return $a;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function listAll()
|
|
|
|
{
|
2018-01-03 22:08:56 +01:00
|
|
|
$all = require (__DIR__ . '/../statics/euler/__all.php');
|
|
|
|
|
|
|
|
return array_map('self::readSingle', $all);
|
2017-11-08 17:39:50 +01:00
|
|
|
}
|
|
|
|
|
2018-01-02 19:41:41 +01:00
|
|
|
public static function getEulerProblemFromStrIdent($ident)
|
|
|
|
{
|
2019-11-02 20:19:34 +01:00
|
|
|
$e = explode('-', $ident, 2); // problem-xxx
|
2018-01-02 19:41:41 +01:00
|
|
|
if (count($e)!==2) return null;
|
|
|
|
|
|
|
|
$i = intval($e[1], 10);
|
|
|
|
if ($i == 0) return null;
|
|
|
|
|
|
|
|
return self::getEulerProblem($i);
|
|
|
|
}
|
|
|
|
|
2018-01-01 21:07:48 +01:00
|
|
|
public static function getEulerProblem($num)
|
|
|
|
{
|
|
|
|
foreach (self::listAll() as $ep) {
|
|
|
|
if ($ep['number'] == $num) return $ep;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2017-11-08 17:39:50 +01:00
|
|
|
public static function rateTime($problem)
|
|
|
|
{
|
|
|
|
if ($problem['time'] < 100) // < 100ms
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
if ($problem['time'] < 15 * 1000) // < 5s
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
if ($problem['time'] < 60 * 1000) // < 1min
|
|
|
|
return 2;
|
|
|
|
|
|
|
|
if ($problem['time'] < 5 * 60 * 1000) // < 5min
|
|
|
|
return 3;
|
|
|
|
|
|
|
|
return 4;
|
|
|
|
}
|
2018-01-27 14:21:34 +01:00
|
|
|
|
|
|
|
public static function checkConsistency()
|
|
|
|
{
|
|
|
|
$warn = null;
|
|
|
|
|
|
|
|
$numbers = [];
|
|
|
|
$realname = [];
|
|
|
|
|
|
|
|
foreach (self::listAll() as $ep)
|
|
|
|
{
|
|
|
|
if (in_array($ep['number'], $numbers)) return ['result'=>'err', 'message' => 'Duplicate number ' . $ep['number']];
|
|
|
|
$numbers []= $ep['number'];
|
|
|
|
|
|
|
|
if (in_array($ep['title'], $realname)) return ['result'=>'err', 'message' => 'Duplicate title ' . $ep['title']];
|
|
|
|
$realname []= $ep['title'];
|
|
|
|
|
|
|
|
if (!file_exists($ep['file_description'])) return ['result'=>'err', 'message' => 'file_description not found ' . $ep['file_description']];
|
|
|
|
if (!file_exists($ep['file_code'])) return ['result'=>'err', 'message' => 'file_code not found ' . $ep['file_code']];
|
|
|
|
if (!file_exists($ep['file_explanation'])) return ['result'=>'err', 'message' => 'file_explanation not found ' . $ep['file_explanation']];
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($warn != null) return $warn;
|
|
|
|
return ['result'=>'ok', 'message' => ''];
|
|
|
|
}
|
2017-11-08 17:39:50 +01:00
|
|
|
}
|
|
|
|
|