openJudge | 过滤多余的空格 C语言

总时间限制: 1000ms 内存限制: 65536kB

描述

一个句子中也许有多个连续空格,过滤掉多余的空格,只留下一个空格。

输入

一行,一个字符串(长度不超过200),句子的头和尾都没有空格。

输出

过滤之后的句子。

样例输入

复制代码
Hello      world.This is    c language.

样例输出

复制代码
Hello world.This is c language.

答案

方法一

c 复制代码
#include <stdio.h>
int main() {
    int switch_ = 0;
    static char str[201], str_[201], *p = str, *q = str_;
    gets(str);
    for(p = str; *p != 0; p++) {
        if(*p == ' ' && switch_ == 0) {
            switch_ = 1;
            *(q++) = *p;
        } else if(*p != ' ') {
            switch_ = 0;
            *(q++) = *p;
        }
    }
    puts(str_);
}

方法二

c 复制代码
#include <stdio.h>
int main() {
    int switch_ = 0;
    static char str[201], *p = str, *q = str;
    gets(str);
    for(p = str; *p != 0; p++) {
        if(*p == ' ' && switch_ == 0) {
            switch_ = 1;
            *(q++) = *p;
        } else if(*p != ' ') {
            switch_ = 0;
            *(q++) = *p;
        }
    }
    puts(str_);
}

方法二

c 复制代码
#include <stdio.h>
int main() {
    int switch_ = 0;
    static char str[201], *p = str, *q = str;
    gets(str);
    for(int i = 0; i < 201; i++, p++) {
        if(*p == ' ' && switch_ == 0) {
            switch_ = 1;
            *(q++) = *p;
        } else if(*p != ' ') {
            switch_ = 0;
            *(q++) = *p;
        }
    }
    puts(str);
}
相关推荐
YGGP26 分钟前
【Golang】LeetCode 64. 最小路径和
算法·leetcode
意趣新1 小时前
C 语言源文件从编写完成到最终生成可执行文件的完整、详细过程
c语言·开发语言
古城小栈2 小时前
Rust变量设计核心:默认不可变与mut显式可变的深层逻辑
算法·rust
电商API&Tina2 小时前
跨境电商 API 对接指南:亚马逊 + 速卖通接口调用全流程
大数据·服务器·数据库·python·算法·json·图搜索算法
LYFlied2 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
lengjingzju3 小时前
一网打尽Linux IPC(三):System V IPC
linux·服务器·c语言
长安er4 小时前
LeetCode 20/155/394/739/84/42/单调栈核心原理与经典题型全解析
数据结构·算法·leetcode·动态规划·
MarkHD4 小时前
智能体在车联网中的应用:第28天 深度强化学习实战:从原理到实现——掌握近端策略优化(PPO)算法
算法
能源系统预测和优化研究4 小时前
【原创代码改进】考虑共享储能接入的工业园区多类型负荷需求响应经济运行研究
大数据·算法
yoke菜籽4 小时前
LeetCode——三指针
算法·leetcode·职场和发展