经典的C语言题型

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

目录

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

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


1. 字符串

1.1 公共字符

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

输入:

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

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

输出:

按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;
}
相关推荐
xyq20243 分钟前
Swift 类
开发语言
赏金术士4 分钟前
Kotlin 从入门到进阶 之异常与标准库(八)
android·开发语言·kotlin
Brilliantwxx4 分钟前
【C++】认识 list(初步认识+模拟实现)
开发语言·数据结构·c++·笔记·算法·list
曹牧4 分钟前
Java:数据载体
java·开发语言
赏金术士6 分钟前
Kotlin 从入门到进阶 之基础语法模块(一)
开发语言·微信·kotlin
格林威6 分钟前
Baumer工业相机堡盟相机Chunk功能全解析:如何在图像中嵌入时间戳、编码器值等元数据?
开发语言·人工智能·数码相机·机器学习·计算机视觉·视觉检测·机器视觉
南宫萧幕7 分钟前
锂电池二阶 RC 模型仿真实战:从理论解析到 Simulink 闭环搭建全流程
开发语言·人工智能·算法·机器学习
水木流年追梦7 分钟前
【python因果库实战29】LaLonde 数据集2
开发语言·python·数据挖掘·langchain·机器人
不会编程的懒洋洋8 分钟前
WPF 性能优化+异步+渲染
开发语言·笔记·性能优化·c#·wpf·图形渲染·线程
故事和你918 分钟前
洛谷-数据结构2-1-二叉堆与树状数组2
开发语言·javascript·数据结构·算法·ecmascript·动态规划·图论