经典的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;
}
相关推荐
xier_ran1 分钟前
【C++】“内部”、“外部”、“派生类”、“友元“类
java·开发语言·c++
Reisentyan2 分钟前
[杭电春季联赛5]1004 赛马
算法
雨墨✘7 分钟前
基于比较的三种排序算法:插入排序、合并排序和快排序
数据结构·算法·排序算法
熬夜敲代码的猫9 分钟前
C/C++:内存管理
c语言·c++·动态内存管理
im_AMBER9 分钟前
从面试题看JS变量提升
开发语言·前端·javascript·前端框架
故事和你919 分钟前
洛谷-数据结构1-2-二叉树1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
大橘10 分钟前
【qml-5.1】qml与c++交互(QML_ELEMENT/QML_SINGLETON)
开发语言·c++·qt·交互·qml
凭君语未可11 分钟前
从静态代理走向动态代理:理解 JDK 动态代理的本质
java·开发语言
xu_wenming11 分钟前
手写数字识别项目教程
网络·算法
_日拱一卒14 分钟前
LeetCode:19删除链表的倒数第N个节点
算法·leetcode·链表