我有一个计算距离的功能,数据来自数据库。
以下是计算代码:
function jarak() {
global $conn;
$query1 = mysqli_query($conn, "SELECT signature, sig_priority FROM centro");
$query2 = mysqli_query($conn, "SELECT signature, sig_priority, status FROM acid_event");
while ($row = mysqli_fetch_array($query1, MYSQLI_ASSOC)) { $master[]=$row; }
while ($row = mysqli_fetch_array($query2, MYSQLI_ASSOC)) { $data[]=$row; }
$jarak = array();
foreach ($data as $key => $val) {
foreach ($master as $key2 => $value) {
$jarak = sprintf("%0.2f",sqrt(pow($val['signature'] - $value['signature'], 2) + pow($val['sig_priority'] - $value['sig_priority'], 2)));
echo "distance from (" . $value['signature'] . "," . $value['sig_priority'] . ") ke (" . $val['signature'] . "," . $val['sig_priority'] . ") is : " . $jarak . "<br>";
$euc[]=$jarak;
}
}
}
这是结果:
Array(
[0] => 30.04
[1] => 0.00
[2] => 30.04
[3] => 0.00
[4] => 47.00
[5] => 17.03
[6] => 5.02
[7] => 25.08
[8] => 2.06
[9] => 32.06
[10] => 37.00
[11] => 7.07 )
我要比较每个大于或小于2的索引数组。 示例:[0]与[1],[2]与[3],[4]与[5]等。它只是与2索引进行比较。
我尝试过但没有结果
for ($i=0; $i<count($cb); $i++) {
for ($k=0;$k<2;$k++) {
if($cb[$i][$k]<$cb[$i][$k]) {
echo "low";
} elseif ($cb[$i][$k]>$cb[$i][$k]) {
echo "high";
}
}
}
我想要的输出应该看起来像这样
如果[0] <[1],则为“高”,并循环到其他索引数组,例如[2]和[3],[4]和[5]等。
答案 0 :(得分:1)
我做了一个解决方案,但是我决定将响应保存在一个数组中,因为对我来说,以后能够在其他地方读取此信息更有意义。
这是我的解决方法:
$test = array(
30.04,
0.00,
30.04,
0.00,
47.00,
17.03,
5.02,
25.08,
2.06,
32.06,
37.00,
7.07,
);
$output = array();
foreach ($test as $key => $value) {
// To make sure this will only be executed every second item
if ($key % 2 !== 0) {
continue;
}
$next = '';
if (!isset($test[$key+1])) {
break;
} else {
$next = $test[$key+1];
}
$output[$key] = $value . ' is ' . ($value < $next
? "lower"
: ($value > $next
? 'higher'
: 'equal')) . ' than ' . $next;
}
echo '<pre>';
print_r($output);
以下是经过测试的代码:https://3v4l.org/Pg5La
答案 1 :(得分:1)
我认为您已经非常接近要完成的目标,但似乎您正在使事情变得比他们需要的更难。
您的代码如下。
for ($i=0; $i<count($cb); $i++) {
for ($k=0;$k<2;$k++) {
if($cb[$i][$k]<$cb[$i][$k]) {
echo "low";
} elseif ($cb[$i][$k]>$cb[$i][$k]) {
echo "high";
}
}
}
正如您所看到的,如果if语句将彼此完全相同的值进行比较,则不会做太多事情。但是我可以在第二个for循环中看到您要做什么。
相反,我们真正想要做的是以2为步长遍历数组。
for ($i=0; $i<count($cb); $i+=2) {
//stuff
}
这样,我们可以将第一个元素与之后的元素相互比较。像这样:
if($cb[$i] > $cb[$i+1]) {
echo $i . 'is higher than '. $i+1;
} elseif($cb[$i] < $cb[$i+1]) {
echo $i . 'is lower than '. $i+1;
} else {
echo $i . 'is the same as '. $i+1;
}
所以总的来说会是这样的:
for ($i=0; $i<count($cb); $i+=2) {
if($cb[$i] > $cb[$i+1]) {
echo $i . 'is higher than '. $i+1;
} elseif($cb[$i] < $cb[$i+1]) {
echo $i . 'is lower than '. $i+1;
} else {
echo $i . 'is the same as '. $i+1;
}
}
现在您可以将回显更改为您想要执行的任何操作,并且您可能还应该添加一些验证(例如,在访问它们之前检查键是否确实存在),但这是一个很好的开始。