私はvariabelの長さの配列を持っており、startdateでソートされたイベントを含み、次のようになっています。
Array
(
[0] => stdClass Object
(
[id] => 1978
[date] => 2012-09-29
)
[1] => stdClass Object
(
[id] => 1979
[date] => 2012-10-14
)
...etc....
イベントの1つを受け取り、正確に7の長さの新しい配列の中央に配置し、イベントのネイバーを両側に配置する関数を作成する必要があります。
したがって、イベント5が関数に渡された場合、出力は次のようになります。
[2][3][4][5][6][7][8]
最初のイベントが関数に渡され、元のイベント数が12の場合、出力は次のようになります。
[10][11][12][1][2][3][4]
イベントの元の量が6で、5番目のイベントが渡された場合、出力は次のようになります。
[2][3][4][5][6][1][]
したがって、イベントのリストは常に新しい配列で「ラップアラウンド」し、可能な限りいっぱいにする必要があります。
私は解決策を一緒にハックしました、それはかなりのステップを含みます。私はそれが本当に好きではありません、そしてそれは私に不思議に思いました:
これはどのようにして最も効率的でエレガントな方法で行われますか?