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);
}
相关推荐
iAkuya37 分钟前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
Root_Hacker37 分钟前
include文件包含个人笔记及c底层调试
android·linux·服务器·c语言·笔记·安全·php
杨间2 小时前
《排序算法全解析:从基础到优化,一文吃透八大排序!》
c语言·数据结构·排序算法
Remember_9932 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
Gorgous—l2 小时前
数据结构算法学习:LeetCode热题100-动态规划篇(下)(单词拆分、最长递增子序列、乘积最大子数组、分割等和子集、最长有效括号)
数据结构·学习·算法
你怎么知道我是队长3 小时前
C语言---未定义行为
java·c语言·开发语言
北京地铁1号线3 小时前
2.3 相似度算法详解:Cosine Similarity 与 Euclidean Distance
算法·余弦相似度
Remember_9933 小时前
【LeetCode精选算法】滑动窗口专题一
java·数据结构·算法·leetcode·哈希算法
小饼干超人4 小时前
详解向量数据库中的PQ算法(Product Quantization)
人工智能·算法·机器学习
你撅嘴真丑4 小时前
第四章 函数与递归
算法·uva