如何按首次出现顺序对字符串中的元音与辅音字符进行分组并排序
技术百科
霞舞
发布时间:2026-01-25
浏览: 次 本文介绍在 php 中如何将字符串拆分为元音和辅音,统一转为小写、去除空格后,**按各字符在原字符串中首次出现的顺序,分别对元音和辅音内部进行频次展开排序**(即相同字符连续排列,且字符块顺序由其首次出现位置决定)。
要实现“按首次出现顺序排序”,关键不在于传统字典序或索引重排,而在于:先提取所有元音(或辅音),再按它们在原始字符串中第一次出现的先后顺序,对去重后的字符列表排序,最后按频次重复拼接。
原代码的问题在于:它只是按遍历顺序简单收集字符($v 和 $c 是稳定顺序),但未对同类字符做归并——导致 aeae 保持交错,而非 aaee。而题目期望的是:同一字符集中,相同字母需连续出现,且不同字母的相对顺序由其在原串中“首次露面”的位置决定。
正确思路如下:
-
预
处理:转小写、移除空格;
-
分离字符集:
- 元音:仅保留 a,e,i,o,u,其余过滤掉;
- 辅音:仅保留非元音的英文字母(即 b-z 排除 aeiou),空格已清除;
- 获取首次出现顺序:使用 str_split() 得到字符数组 → 遍历并记录每个字符首次出现的索引(或更简洁地:用 array_unique() 保持键值顺序);
- 频次统计 + 有序拼接:借助 array_count_values() 统计频次,再结合原始字符流中去重后的顺序(即 array_unique($chars) 的结果)来控制输出序列。
但注意:array_count_values() 本身不保证键的顺序,因此必须配合原始遍历顺序。更健壮、清晰的实现方式如下(优化版,含注释与可读性提升):
function sortCharsByFirstOccurrence(string $text): array
{
$lower = strtolower(str_replace(' ', '', $text));
$chars = str_split($lower);
$vowels = ['a', 'e', 'i', 'o', 'u'];
// 提取元音和辅音(保持原始顺序)
$vowelList = array_filter($chars, fn($c) => in_array($c, $vowels));
$consonantList = array_filter($chars, fn($c) => ctype_alpha($c) && !in_array($c, $vowels));
// 按首次出现顺序去重(保留键,确保顺序)
$uniqueVowels = array_values(array_unique($vowelList));
$uniqueConsonants = array_values(array_unique($consonantList));
// 统计频次
$vowelCounts = array_count_values($vowelList);
$consonantCounts = array_count_values($consonantList);
// 拼接:按 unique 列表顺序,重复对应次数
$vowelsResult = '';
foreach ($uniqueVowels as $v) {
$vowelsResult .= str_repeat($v, $vowelCounts[$v] ?? 0);
}
$consonantsResult = '';
foreach ($uniqueConsonants as $c) {
$consonantsResult .= str_repeat($c, $consonantCounts[$c] ?? 0);
}
return [
'vowels' => $vowelsResult,
'consonants' => $consonantsResult
];
}
// 使用示例
$result = sortCharsByFirstOccurrence('Sample Case');
echo "vowels : {$result['vowels']}\n";
echo "consonants : {$result['consonants']}\n";✅ 输出:
vowels : aaee consonants : ssmplc
? 关键说明:
- array_unique($vowelList) 返回的数组保留了首个匹配元素的原始键位,因此 ['s','a','m','p','l','e','c','a','s','e'] 中元音提取为 ['a','e','a','e'] → array_unique 得 ['a','e'],完美对应首次出现顺序;
- str_repeat($char, $count) 确保相同字符连续排列;
- 使用 ctype_alpha() 替代硬编码辅音列表,更健壮(兼容未来扩展,且避免遗漏如 'y' 等边界情况);若严格按 b-z\aeiou 定义辅音,亦可改用正则 /[^aeiou\d\s]/ 过滤。
? 小结:本方案本质是「稳定频次展开」——不是排序,而是按首次出现顺序枚举唯一字符,再按全局频次填充。它兼具可读性、健壮性与扩展性,适用于任意 ASCII 字母字符串处理场景。
# 的是
# 适用于
# 首次
# 而非
# 亦可
# 首个
# 留了
# 编码
# 字符串
# 排列
# char
# ASCII
# php
# 遍历
# count
# 再按
# 由其
# Chars
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win11截图快捷键是什么_Win11自带截图工具
- c++如何使用std::bitset进行位图算法_
- 如何用正则表达式精确匹配“start”到“end”
- Win10如何关闭安全中心所有通知 Win10禁用
- Windows10任务栏图标变成白色文件_Win1
- 使用类变量定义字符串常量时如何实现类型安全的 Li
- 零基础学会Python自动化办公_高效处理Exce
- Go 中 defer 在 goroutine 内部
- Win11如何关闭游戏模式 Win11禁用Xbox
- VSC怎么创建PHP项目_从零开始搭建项目的步骤【
- Python网络日志追踪_请求定位解析【教程】
- 电脑的“网络和共享中心”去哪了_Windows 1
- Win11怎样安装微信开发者工具_Win11安装开
- PHP 中如何在函数内持久化修改引用变量的指向
- 获取 PHP 文件最后修改时间的正确方法
- Win11怎么关闭自动调节屏幕亮度_Windows
- Win11怎么设置ipv4地址_Windows 1
- 如何在Golang中配置代码格式化工具_使用gof
- 如何使用Golang搭建Web开发环境_快速启动H
- VSC怎样在VSC中调试PHPAPI_接口调试技巧
- Linux怎么禁止Root用户远程登录_Linux
- 为什么Go建议使用error接口作为错误返回_Go
- 如何在同包不同文件中正确引用 Go 结构体
- Win10电脑怎么设置网络名称_Windows10
- 如何在Golang中引入测试模块_Golang测试
- Python对象比较与排序_魔术方法解析【教程】
- 如何在 Go 中正确测试带 Cookie 的 HT
- 如何高效识别并拦截拼接式恶意域名 spam
- 如何在 Python 中将 ISO 8601 时间
- c# Task.ConfigureAwait(tr
- Windows蓝屏BAD_POOL_HEADER故
- 如何在Golang中使用log包输出不同级别日志_
- Win10如何备份注册表_Win10注册表备份步骤
- Windows家庭版如何开启组策略(gpedit.
- Win11怎么设置ip地址_Windows 11手
- Win10如何卸载微软拼音输入法 Win10只保留
- c# 如何深拷贝和浅拷贝
- 如何在Golang中处理数据库事务错误_回滚和日志
- c++中的Tag Dispatching是什么_c
- 如何在Golang中处理模块包路径变化_Golan
- PHP主流架构如何处理会话管理_Session与C
- php订单日志怎么按金额排序_php按订单金额排序
- php和redis连接超时怎么办_phpredis
- Windows10怎么备份注册表_Windows1
- Flask 表单数据通过 SMTP 发送邮件的完整
- c++ reinterpret_cast怎么用 c
- php订单日志怎么记录物流_php记录订单物流变更
- PHP 中如何在函数内持久修改引用变量所指向的目标
- php下载安装后swoole扩展怎么安装_异步框架
- 如何优化Golang程序CPU性能_Golang


QQ客服