经典的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;
}
相关推荐
方也_arkling8 小时前
【Java-Day08】static / final / 枚举
java·开发语言
风吹夏回8 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
Chengbei119 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1129 小时前
web-第一次课后作业
java·开发语言·idea
kkeeper~9 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
小熊Coding9 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋99 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
xiaoshuaishuai89 小时前
C# 内存管理与资源泄漏
开发语言·c#
lsx20240610 小时前
SVN 检出操作
开发语言
wabs66610 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘