Zitat von
himitsu:
Du weißt aber, daß JSON eh keine "echten" Konstanten kennt, da es "nur" ein Format einer ScriptSprache ist und somit alles "nur" dynamisch verwaltet wird.
(dieses JSON-String wird da auch erst zur Laufzeit über einen Parser zerlegt)
Ja, das ist schon klar, ich habe das nur als JSON geschrieben um zu verdeutlichen, was ich nachher im Speicher stehen haben will. Nur um eine Vorstellung zu vermitteln. Ich hätte es natürlich auch auf deutsch ausformulieren können, aber das wäre dann vermutlich auch schlecht zu verstehen gewesen.
Ich habe rein zu Demonstrationszwecken den KMP-Algorithmus implementiert und ein paar einfach test cases geschrieben, die ich einfach zu Demonstrationszwecken drüberrasseln lassen kann.
Delphi-Quellcode:
// == Defining test cases == //
// 1. testcase (pattern + text is identical)
testCases[0].pattern := 'aababaab';
testCases[0].text := testCases[0].pattern; // text and pattern is identical
// there should be exactly one occurence at the first character of the string
SetLength(testCases[0].occurences, 1);
testCases[0].occurences[0] := 1;
// 2. testcase (pattern occures somewhere in the middle)
testCases[1].pattern := 'aababaab';
testCases[1].text := 'aaa' + testCases[1].pattern + 'aaa';
// there should be exactly one occurence at the fourth character of the string
SetLength(testCases[1].occurences, 1);
testCases[1].occurences[0] := 4;
// 3. testcase: (pattern does not occur in the string)
testCases[2].pattern := 'aababaab';
testCases[2].text := 'aaaaaabbbbbbbbaaaabbbbhhhhhaaadddd';
// there should be no occurences
SetLength(testCases[2].occurences, 0);
// 4. testcase: (pattern occures several time without overlapping each other)
testCases[3].pattern := 'aababaab';
testCases[3].text := 'aa' + testCases[3].pattern + 'a' + testCases[3].pattern;
// there should be two occurences at the 3rd and 12th character of the string
SetLength(testCases[3].occurences, 2);
testCases[3].occurences[0] := 3;
testCases[3].occurences[1] := 12;
// 5. testcase (pattern occures several times with overlapping each other)
testCases[4].pattern := 'aababaab';
testCases[4].text := 'aababaababaab';
// there should be two occurences at the 1st and 6th character of the string
SetLength(testCases[4].occurences, 2);
testCases[4].occurences[0] := 1;
testCases[4].occurences[1] := 6;
// DONE: Building test cases
Gut, geht natürlich. Aber so richtig hyperübersichtlich ist es dann finde ich doch nicht. Vorallem, weil es auch etwas fehleranfällig ist, wenn man einmal sich beim setlength vertut oder bei einem array index. Das könnte man ja theoretisch auch automatisch auflösen. Also wenn da noch wer eine Idee hat...
Letzter Tipp: Drogen. Machen zwar nicht glücklich, geben einem aber wenigstens das Gefühl glücklich zu sein.
Have a lot of fun!