每日一题:C语言经典例题之字符串的处理

题目描述

字符串的输入输出处理。

输入

第一行是一个正整数N,最大为100。之后是多行字符串(行数大于N), 每一行字符串可能含有空格,字符数不超过1000。

输出

先将输入中的前N行字符串(可能含有空格)原样输出,再将余下的字符串(不含有空格)以空格或回车分割依次按行输出。每行输出之间输出一个空行。

代码:

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

#define MAX_LINES 100
#define MAX_LINE_LENGTH 1001

int main() {
    int N;
    scanf("%d", &N);

    char lines[MAX_LINES][MAX_LINE_LENGTH];
    int current_line = 0;

    while (current_line < N && fgets(lines[current_line], MAX_LINE_LENGTH, stdin)) {
        ++current_line;
    }

    // 输出前N行(含空格)
    for (int i = 0; i < current_line; ++i) {
        printf("%s", lines[i]);
        if (i < current_line - 1) {  // 不在最后一行时输出换行符
            printf("\n");
        }
    }

    // 输出剩余行(不含空格)
    char no_space_line[MAX_LINE_LENGTH];
    while (fgets(lines[current_line], MAX_LINE_LENGTH, stdin)) {
        // 去除字符串中的空格
        int len = strlen(lines[current_line]);
        int j = 0;
        for (int i = 0; i < len; ++i) {
            if (lines[current_line][i] != ' ') {
                no_space_line[j++] = lines[current_line][i];
            }
        }
        no_space_line[j] = '\0';  // 添加结束符

        printf("%s\n", no_space_line);  // 输出当前行
        printf("\n");  // 输出一个空行

        ++current_line;
    }

    return 0;
}
相关推荐
CoovallyAIHub1 小时前
中科大DSAI Lab团队多篇论文入选ICCV 2025,推动三维视觉与泛化感知技术突破
深度学习·算法·计算机视觉
NAGNIP2 小时前
Serverless 架构下的大模型框架落地实践
算法·架构
moonlifesudo2 小时前
半开区间和开区间的两个二分模版
算法
moonlifesudo2 小时前
300:最长递增子序列
算法
CoovallyAIHub7 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
CoovallyAIHub8 小时前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI1 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v1 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工1 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js