经典的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;
}
相关推荐
small_wh1te_coder2 小时前
拷打字节技术总监: 详解c语言嵌入式多线程编程中的头文件 #总结 上下篇合 #
c语言·开发语言·算法·操作系统·嵌入式
凌盛羽2 小时前
使用python绘图分析电池充电曲线
开发语言·python·stm32·单片机·fpga开发·51单片机
wangjialelele2 小时前
现代C++:C++17新特性整理
c语言·开发语言·c++·visual studio code
字节高级特工2 小时前
C++从入门到熟悉:深入剖析const和constexpr
前端·c++·人工智能·后端·算法
Cathy Bryant2 小时前
聊聊拓扑学
笔记·算法·数学建模·拓扑学·高等数学
Lisssaa2 小时前
打卡第二十七天
算法
XWalnut2 小时前
LeetCode刷题 day2
算法·leetcode·职场和发展
Tisfy2 小时前
LeetCode 2946.循环移位后的矩阵相似检查:模拟(左即是右)
算法·leetcode·矩阵·题解
肖恭伟2 小时前
Curso调试Qt:GDB + Qt 官方 qt5printers.py + .gdbinit
开发语言·qt