登录
首页 >  文章 >  php教程

按首次出现顺序排序元音与辅音字符

时间:2026-02-05 13:39:46 326浏览 收藏

本篇文章向大家介绍《按首次出现顺序对字符串中的元音与辅音字符分别排序,可以按照以下步骤进行:步骤说明:定义元音字母:元音包括 a, e, i, o, u(不区分大小写)。遍历字符串:从左到右逐个检查每个字符。分类存储:如果是元音,按首次出现的顺序添加到元音列表中。如果是辅音,按首次出现的顺序添加到辅音列表中。合并结果:将元音列表和辅音列表合并成最终结果。示例代码(Python): def sort_vowels_consonants(s): vowels = [] consonants = [] seen_vowels = set() seen_consonants = set() for char in s: if char.lower() in {'a', 'e', 'i', 'o', 'u'}: if char.lower() not in seen_vowels: vowels.append(char) seen_vowels.add(char.lower()) else: if char.lower() not in seen_consonants: consonants.append(char) seen_consonants.add(char.lower()) return ''.join(vowels + consonants) # 示例 input_str = "Hello World" result = sort_vowels_conson》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

如何按首次出现顺序对字符串中的元音与辅音字符分别排序

本文介绍在 PHP 中如何将字符串拆分为元音和辅音字符,统一转为小写并去除空格后,**按各字符在原字符串中首次出现的顺序进行分组排序**(即相同字符按频次重复,但整体保持“先出现的字符类型优先排列”),而非简单按字母表顺序排序。

要实现“按首次出现顺序排序”,关键在于:不改变字符类别的相对位置顺序,仅对同一类别内的重复字符做频次聚合,并保持该字符第一次出现时的先后次序。例如 'Sample Case' 中,元音 a 首次出现在索引 1(Sample...),e 首次出现在索引 4(Sample...),因此最终元音结果应为 aaee(两个 a 在前,两个 e 在后);同理,辅音 s 首次出现在索引 0 和索引 6(S 和 Case 中的 s),故 s 排最前,后续依次是 m, p, l, c → 拼出 ssmplc。

下面是一个清晰、健壮的实现方案:

function sortCharactersByFirstOccurrence($text) {
    $text = strtolower(str_replace(' ', '', $text));
    $vowels = ['a', 'e', 'i', 'o', 'u'];

    // 提取所有元音和辅音(保留原始顺序)
    $allVowels = [];
    $allConsonants = [];

    for ($i = 0; $i < strlen($text); $i++) {
        $char = $text[$i];
        if (in_array($char, $vowels)) {
            $allVowels[] = $char;
        } else {
            $allConsonants[] = $char;
        }
    }

    // 统计频次,并按首次出现顺序拼接
    $vowelFreq = [];
    $consonantFreq = [];

    // 元音频次统计(保持首次出现顺序)
    foreach ($allVowels as $v) {
        if (!isset($vowelFreq[$v])) {
            $vowelFreq[$v] = 1;
        } else {
            $vowelFreq[$v]++;
        }
    }

    // 辅音同理
    foreach ($allConsonants as $c) {
        if (!isset($consonantFreq[$c])) {
            $consonantFreq[$c] = 1;
        } else {
            $consonantFreq[$c]++;
        }
    }

    // 按原始出现顺序去重得到字符序列(PHP 7.4+ 可用 array_keys(array_flip(...)),但此处手动保序更明确)
    $orderedVowels = array_values(array_unique($allVowels));
    $orderedConsonants = array_values(array_unique($allConsonants));

    // 构建结果
    $vowelResult = '';
    foreach ($orderedVowels as $v) {
        $vowelResult .= str_repeat($v, $vowelFreq[$v]);
    }

    $consonantResult = '';
    foreach ($orderedConsonants as $c) {
        $consonantResult .= str_repeat($c, $consonantFreq[$c]);
    }

    echo "Vowels     : {$vowelResult}\n";
    echo "Consonants : {$consonantResult}\n";
}

// 测试
sortCharactersByFirstOccurrence('Sample Case');

输出:

Vowels     : aaee
Consonants : ssmplc

核心要点总结:

  • 先清洗字符串(小写 + 去空格),再逐字符遍历,严格按原始位置分离元音/辅音
  • 使用 array_unique()(配合 array_values())提取首次出现顺序的不重复字符列表,确保拼接时顺序正确;
  • 利用关联数组统计频次,再按保序后的字符键循环拼接,实现“同字符聚集 + 类别内首现优先”;
  • 避免使用 sort() 或 ksort() —— 它们会破坏原始位置逻辑;
  • 此方案兼容含重复字符、大小写混合、多空格等常见边界情况。

该方法语义清晰、易于维护,适用于文本分析、密码学预处理或教学演示等需要保留字符时序特征的场景。

理论要掌握,实操不能落!以上关于《按首次出现顺序排序元音与辅音字符》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>