データ構造とアルゴリズム(PHP記述) トリプレット トリプレット
- /**
- *トリプレット
- */
- class Triplet
- {
- private $_data = null;
- // トリプレットを初期化する
- public function init($val1, $val2, $val3)
- {
- $this -> _data[0] = $val1;
- $this ->data[1] = $val2;
- $this -> _data[2] = $val3;
- return true;
- } / トリプルを破棄します
- public function destroy()
- {
- unset($this -> _data);
- return true;
- }
- // $key の値を返します
- public function get($key)
- {
- if ($key < 1 || $key > 3) return false;
- return$this -> _data[$key-1];
- }
- // $key 要素の値を $val に設定します
- public function put($key, $val)
- {
- if ($key 3) return false;
- $this -> _data[$key-1] = $val;
- return true; ;
- }
- // 昇順でソートするかどうか
- public function isAscending()
- {
- return ($this -> _data[0] <= $this -> _data[1]) && ($this - < _data[1] <= $this -> _data[2]);
- }
- // 降順でソートするかどうか
- public function isDescending()
- {
- return ($this -> _data[0 ] > ;= $this -> _data[1]) && ($this -> _data[1] >= $this -> _data[2]);
- }
- // 最大値を取得する
- public function max( )
- {
- return ($this -> _data[0] >= $this -> _data[1])? ($this -> _data[0] >= $this -> _data[2 ])?$this -> _data[0] :$this -> _data[2] : ($this -> _data[1] >= $this -> _data[2])? $this - > _data[1] :$this -> _data[2];
- }
- // 最小値を取得します
- public function min()
- {
- return ($this -> _data[0] < ;= $this -> _data[1])? ($this -> _data[0] <= $this -> _data[0] :$this - > _data[ 2] : ($this -> _data[1] <= $this -> _data[2])?$this -> _data[2] ;
- }
- }
-
- $objTriplet = new Triplet();
- echo"init:";
- var_dump($objTriplet -> init(1, 2, 3));
- echo"
" ;
-
- echo "get 1:";
- var_dump($objTriplet -> get(1));
- echo"
";
- echo"get 4:";
- var_dump($objTriplet -> ; get(4 ));
- echo"
"; // false - echo"put 3,4:";
- var_dump($objTriplet -> put(3, 4));
- echo"
";
-
- echo"max:";
- var_dump($objTriplet -> max());
- echo"
"; - echo"min:";
- var_dump( $objTriplet -> ; min());
- echo"
"; - echo"isAscending:";
- var_dump($objTriplet -> isAscending());
- echo"
echo"isDescending:"; - var_dump($objTriplet -> isDescending());
- echo"
";
-
- ?>
-
コードをコピー
|