数组的排序问题!
$a=array('张三'=>'肆佰贰拾叁','李四'=>'壹佰玖拾','王五'=>'柒佰','孙六'=>'捌仟叁佰陆拾','陈七'=>'肆万伍仟贰佰');
将这个数组按汉子代表的数字大小进行排序,不改变索引,最后输出的结果应为如下格式:
array('李四'=>'壹佰玖拾','张三'=>'肆佰贰拾叁','王五'=>'柒佰','孙六'=>'捌仟叁佰陆拾','陈七'=>'肆万伍仟贰佰');
代码尽量简单 我是新手,最后排序用数组排序函数
------解决方案--------------------
$a = array(<br /> '张三' => '肆佰贰拾叁',<br /> '李四' => '壹佰玖拾',<br /> '王五' => '柒佰',<br /> '孙六' => '捌仟叁佰陆拾',<br /> '陈七' => '肆万伍仟贰佰'<br />);<br /><br />$t = array_map('cton', $a);<br />array_multisort($t, $a);<br />print_r($a);<br /><br />function cton($s) {<br /> $dw = array('拾' => 10, '佰' => 100, '仟' => 1000, '万' => 10000);<br /> $digital = array('零' => 0, '壹' => 1, '贰' => 2, '叁' => 3, '肆' => 4,<br /> '伍' => 5, '陆' => 6, '柒' => 7, '捌' => 8, '玖' => 9);<br /> $ar = preg_split('/(' . join('<br><font color='#FF8000'>------解决方案--------------------</font><br>', array_keys($dw)) . ')/',<br /> $s, -0, PREG_SPLIT_NO_EMPTY <br><font color='#FF8000'>------解决方案--------------------</font><br> PREG_SPLIT_DELIM_CAPTURE);<br /> for($i=0; $i<count($ar); $i+=2) {<br /> $res[] = $digital[$ar[$i]] * (isset($ar[$i+1]) ? $dw[$ar[$i+1]] : 1);<br /> }<br /> return array_sum($res);<br />}Array<br />(<br /> [李四] => 壹佰玖拾<br /> [张三] => 肆佰贰拾叁<br /> [王五] => 柒佰<br /> [孙六] => 捌仟叁佰陆拾<br /> [陈七] => 肆万伍仟贰佰<br />)<br /><br />
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
C++高性能并发应用_C++如何开发性能关键应用
Java AI集成Deep Java Library_Java怎么集成AI模型部署
Golang后端API开发_Golang如何高效开发后端和API
Python异步并发改进_Python异步编程有哪些新改进
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
Java GraalVM原生镜像构建_Java怎么用GraalVM构建高效原生镜像
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
C++现代C++20/23/26特性_现代C++有哪些新标准特性如modules和coroutines
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号