经典的C语言题型

该文章主要介绍一些经典的C语言题型。

目录

[1. 字符串](#1. 字符串)

[1.1 公共字符](#1.1 公共字符)


1. 字符串

1.1 公共字符

题目: 给定一组字符串strings ,请计算有哪些字符在所有字符串中都出现过count次及以上。

输入:

第一个参数是count,1<= count<=100

第二个参数是strings,1<=strings**.**length<=100,1<=stringsi.length<1000,stringsi仅由英文和数字组成

输出:

按ASCII码升序输出所有符合要求的字符;如果没有符合要求的字符,则输出空列表

样例1

输入:2

"aabbccFFFx2x2","aaccddFFFFx2x2","aabcdFFFFx2x2"

输出: "2","F","a","x"

代码实现:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

static char *CommonChars(int count, char **strings, size_t stringsSize, size_t *returnSize)

{
    int minFreq[128];

    // 初始化为一个大值
    for (int i = 0; i < 128; i++) {
        minFreq[i] = 1000;
    }
    // 遍历每个字符串
    for (size_t i = 0; i < stringsSize; i++) {
        int freq[128] = {0};
        char *str = strings[i];
        // 统计当前字符串频率
        for(int j = 0; str[j] != '\0'; j++) {
            freq[(int)str[j]]++;
        }
        // 更新最小频率
        for (int k = 0; k < 128; k++) {
            if (freq[k] < minFreq[k]) {
                minFreq[k] = freq[k];
            }
        }
    }

    // 分配结果空间(最多128个字符)
    char *result = (char *)malloc(128 * sizeof(char));
    *returnSize = 0;

    // 收集符合条件的字符(按ASCII顺序)
    for (int i = 0 ; i < 128; i++) {
        if (minFreq[i] >= count) {
            result[*returnSize] = (char)i;
            (*returnSize)++;
        }
    }
    return result;
}

// 以下为一个例子
int main() {
    int count = 2;
    char* strings[] = {"aabbccFFFx2x2", "aaccddFFFFx2x2", "aabcdFFFFx2x2"};
    size_t strSize = 3;
    size_t retSize;

    char* res = CommonChars(count, strings, strSize, &retSize);

    // 按题目格式输出
    printf("[");
    for (int i = 0; i < retSize; i++) {
        if (i > 0) printf(",");
        printf("\"%c\"", res[i]);
    }
    printf("]\n");

    free(res); // 释放内存
    return 0;
}
相关推荐
JieE21214 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21214 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术18 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦20 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
LDR0062 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术2 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript