PHP は位置アルゴリズムを変更せずに配列の長さに応じてソートします。先生方、助けてください
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ -->$arr = array('宫颈糜烂','治疗','治疗宫颈','宫颈','糜烂','如何治疗','如何','治宫颈','怎样','怎样治疗','宫糜'); function arrLenOrder_desc($a,$b) { if (strlen($a) == strlen($b)) return 0; return (strlen(strip_tags($a)) < strlen(strip_tags($b))) ? 1 : -1; } usort($arr,"arrLenOrder_desc"); echo implode(",",$arr); /*输出*/ //怎样治疗,宫颈糜烂,如何治疗,治疗宫颈,治宫颈,治疗,怎样,宫糜,如何,糜烂,宫颈 /*但我想要的结果是(即如果长度一样不改变原来顺序):*/ //宫颈糜烂,治疗宫颈,如何治疗,怎样治疗,治宫颈,治疗,宫颈,糜烂,如何,怎样,宫糜
$arr = array('子宮頸部びらん','治療','子宮頸部の治療','子宮頸部','びらん','治療方法','方法','子宮頸部の治療','方法','方法ごちそうします」、「ゴンミ」); $a_k = 配列キー($arr); $a_v = array_map(create_function('$item', 'return strlen($item);'),$arr); array_multisort($a_v,SORT_DESC,SORT_NUMERIC,$a_k,SORT_ASC,SORT_NUMERIC,$arr); echo implode(",",$arr);