🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

277閲覧

4チームの振り分けがうまくいかない

zerosan96

総合スコア4

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2019/10/08 06:55

とあるシステムでチーム分け機能を作っています。

チームのHPが0で、一番少ないチームを取得しているはずなのですがなぜか$minteamが定義されていないとでます。なにか改善点がありましたらご教示願います

php

1 $this->red = array(); 2 $this->green = array(); 3 $this->blue = array(); 4 $this->yellow = array(); 5 6 /* HP 7 8 rhp,ghp,bhp,yhp = 75; 9 10 */ 11 12 public function getMinTeam(){ 13 14 if(min($this->red,$this->green,$this->blue,$this->yellow) === $this->red && $this->plugin->game->rhp !== 0){ 15 16 $minteam = "red"; 17 18 }elseif(min($this->green,$this->blue,$this->yellow) === $this->green && $this->plugin->game->ghp !== 0){ 19 20 $minteam = "green"; 21 22 }elseif(min($this->blue,$this->yellow) === $this->blue && $this->plugin->game->bhp !== 0){ 23 24 $minteam = "blue"; 25 26 }elseif($this->plugin->game->yhp !== 0){ 27 28 $minteam = "yellow"; 29 30 } 31 32 return $minteam; 33 34 }

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yambejp

2019/10/08 07:02

クラスで処理しているならそこから明示してください 空の配列を比較する意味はあるのでしょうか?それともなにかデータが与えられているのでしょうか? プラグインの仕様もよくわかりません
sakura_hana

2019/10/08 08:59

・minにarrayを入れた時と数値を入れた時では返って来る結果が違うが理解出来ているのか。 https://www.php.net/manual/ja/function.min.php ・前提条件は「チームのHPが0で、」なのにif文では「チームのHPが0ではない時」になっている。 ・「一番少ないチームのHPが0ではない」時はどうするのか。 この辺を確認&考える必要があるかと思います。
m.ts10806

2019/10/08 11:56

他者がコピペで動かせる(現象確認できる)コードをご提示ください。
guest

回答2

0

なぜか$minteamが定義されていない

それはまぁ、初期値を設定していませんし、elseを設置していないので
$minteamが定義されないパターンは存在しますよね。

「~なはず」と言ってもコードは書いた通り、組んだ通りしか動かないので
きちんとデバッグして流れを追ってください。

投稿2019/10/08 11:58

m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

HP0のチームを拾ってからminした方がスマートな気がしたよ

php

1<?php 2public function getMinTeam(){ 3 $teams_has_zero_hp=[]; 4 foreach(['red'=>'rhp','green'=>'ghp','blue'=>'bhp','yellow'=>'yhp'] as $color=>$hp_key){ 5 if($this->plugin->game->$hp_key==0){$teams_has_zero_hp[$color]=$this->$color;} 6 } 7 if(empty($teams_has_zero_hp)){return null;} 8 return array_keys($teams_has_zero_hp ,min($teams_has_zero_hp)); 9}

お節介なことを言うと、チームのクラスを作って
ゲームクラスは各々のチームをプロパティで持つんじゃなく
配列でチームの情報をまとめて持った方が取り回しがいいと思う


仕様を読み違えてたので修正

投稿2019/10/09 11:34

編集2019/10/09 13:03
KazuhiroHatano

総合スコア7819

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問