亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在數組中找到下一個更大的數字和下一個更小的數字

如何在數組中找到下一個更大的數字和下一個更小的數字

PHP
慕工程0101907 2022-12-30 16:06:02
最初,我有一個值,可以說100。然后我還有一個包含元素的數組[99, 101, 102, 103, 98, 95, 97]我想要的是,我想要一個新數組有一個最接近值的第一個元素,100 即101&99然后下一個最接近的值是102&98等等。所以最后的數組會是這樣的[99, 101, 98, 102, 97, 103, 95]那么在 php 中我該如何解決這個問題呢?這個問題有什么具體的算法嗎?
查看完整描述

2 回答

?
慕斯709654

TA貢獻1840條經驗 獲得超5個贊

您可以簡單地在關聯數組中收集數字,鍵為與 100 的差值。稍后,您可以ksort()根據差值對它們進行排序。這樣,在很多普通情況下,您的分揀成本將降至最低。


<?php


$a = array(99, 95, 101, 102, 103, 98, 97, 110);


$number = 100;

$diff = [];


foreach($a as $ele){

    $diff[abs($number - $ele)][] = $ele;

}


ksort($diff,SORT_NUMERIC);

print_r($diff);

演示: https ://3v4l.org/QPX1o


查看完整回答
反對 回復 2022-12-30
?
慕村225694

TA貢獻1880條經驗 獲得超4個贊

您可以使用usortorder 通過您定義的函數對數組進行排序。正如@Pedro Pinheiro 在評論中提到的,您可以計算分數,表示元素與 100 的距離,這正是 usort 得到的。


所以你的代碼可以是:


<?php

function sort_100($a,$b)

{

if ($a==$b) return 0;

return (abs(100-($a))<abs(100-($b))?-1:1;

}


$a=array(99, 101, 102, 103, 98, 95, 97);

usort($a,"sort_100");

?>


查看完整回答
反對 回復 2022-12-30
  • 2 回答
  • 0 關注
  • 155 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號