#include <stdio.h>
#include <string.h>
#include <errno.h> #define BUF_SIZE 128
/*
* 要求:处理一个字符串,删除字符串中多余的空格、'\t'和空行,并满足下列要求:
* (1)对原字符串只能进行一次扫描。
* (2)不允许申请新的空间。(这个有点疑问,声明变量也会申请空间的。)
* (3)处理后的字符串的首尾不能有空格、'\t'和空行。
* (4)如果原字符串中连续出现空格和'\t',则处理后的字符串只需存储一个空格。
* (5)如果原字符串中连续出现空格、'\t'和空行,则处理后的字符串只需存储一个空行
* (对这个空行理解也不清楚是一个\n,还是两个\n?,字符串后两个\n才会出一
*  个可见的空行,这个地方可能是 \n 我以为)。
*
* 这个题花了我两个小时,写了三遍。
* 总结: 1.对问题的理解很重要.
* 2.把问题转换成合理的模型,可以减少许多工作.
* 3.每个局部都正确,不代表整体有意义.
*
* 这个题的处理模型就是字符串拷贝。
* 但有条件.就是上面说的,转换成程序是这样的。。。。看代码吧,
* 写的注释都多余.
*
* 关于 bug 为何不直接修正,因为我看人家都只给的函数。
*/ /*
* FIXME: 如果修正bug 的话,这里将会修改成
* -----------
* char remove_extra_space(char *str, int is_trim_header)
* -----------
*/
void remove_extra_space(char *str)
{
char *s = str; //代表生成的字符串,因为 s 多表示临时字符串。
char *prv = NULL; //代表上一个有效的字符.这个有效的是指...(你应该明白的) for(; prv==NULL ||*prv != '\0'; ++str){ //这个的好处在于 不会遗忘掉 ++str.而且 continue 后还能执行.
switch (*str){ case '\t': *str = ' '; //方便统一处理.因为结果都是空格
case ' ' :
/*
* FIXME: 如果修正bug 的话,这里将会修改成
* -----------
* if ( (prv == NULL && is_trim_header != 0) || *prv == '\n' || *prv ==' '){
* -----------
*/
if (prv == NULL || *prv == '\n' || *prv ==' '){
continue;
}
break; case '\0':
case '\n':
if (prv == NULL){
/*
* FIXME: 如果修正bug 的话,这里将会修改成
* -----------
* if (*str == '\n' && is_trim_header != 0)
* -----------
*/
if (*str == '\n')
continue;
}
else if ( *prv == ' ' || *prv == '\n'){
*prv = *str;
/*
* FIXME:这个地方获取返回值,返回值初始值 '\0'
*/
continue;
}
break;
} if (s != str){
*s = *str;
}
prv = s;
++s;
}
/*
* FIXME: 返回返回值.
*/
} int main(int argc,char *argv[])
{
char read_buf[BUF_SIZE] = {'\0'};
int read_size = ; errno = ; while ((read_size = fread(read_buf, sizeof (char), BUF_SIZE-, stdin)) >){
read_buf[read_size] = '\0'; /*
* FIXME:注意这个地方有 bug, 读取文件被分成 BUF_SIZE 的小块,
* 如果刚好在有空格(或 '\t' )处分割,则会缺少个空格.
* 如果在换行前分割,会丢失换行.
* 解决放案是传入个 int is_trim_header (是否消除字符串开始处的空白或换行);
* 如果 is_trim_header 不为 0 则 不保留开始处的空格,
* 为 0 则 按照空格是出现在句子中间或末尾的情况处理.
*
* 这里要判断行上次行末,和这次行首是否有空白符用来确定 is_trim_header 的值.
* 这里还需要 remove_extra_space 返回读到 \0 时删掉的字符,才能确定如何补偿
* 空格还是回车
*
*
* if (上行删掉的是\n && 本行有内容) 补偿 \n,is_trim_header = 1;
* else if (上行删掉的是' ' && 本行有内容) is_trim_header = 0;
* else is_trim_header = 1;
*/ remove_extra_space(read_buf); printf("%s",read_buf);
} if (errno != ){
printf(strerror(errno));
} return ;
}

c 语言练习__去掉多余的空白字符_修正的更多相关文章

  1. 【代码笔记】iOS-浮点数处理并去掉多余的0

    一,代码. - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. ...

  2. Birt设置导出格式和去掉多余按钮的方法

    1.设置导出格式: webcontent>birt>pages>dialog>ExportReportDialogFragment.jsp页面: 找到for ( int i = ...

  3. 删除字符串中多余的空白字符和空行(C语言实现)

    要求:处理一个字符串,删除字符串中多余的空格.水平制表符和空行,并满足下列要求: (1)对原字符串只能进行一次扫描.(2)不允许申请新的空间.(3)处理后的字符串的首尾不能有空格.制表符和空行.(4) ...

  4. .NET Core 发布时去掉多余的语言包文件夹

    用 .NET Core 3.x 作为目标框架时发布完之后,会发现多了很多语言包文件夹,类似于: 有时候,不想要生成这些语言包文件夹,需要稍微配置一下. 在 PropertyGroup 节点中添加如下的 ...

  5. DataGridView 去掉多余的列

    去掉DataGridView多余的列: this.DataGridView.AutoGenerateColumns = false;

  6. magento的url中 去掉多余的目录层级

    有时我们需要仅仅显示一层目录的URL路径.而不要出现多个路径的现实,我们可以用以下方法修改: Edit  /app/code/core/Mage/Catalog/Model/Url.php 找到632 ...

  7. mongodb转换List实体(去掉多余的字段) 批量添加

    Gson gson = new Gson(); String str = "list集合json字符串"; JsonObject object = gson.fromJson(st ...

  8. 正则匹配 去掉 多余的js和html标签

    $reg17 = '/><strong>公司介绍<\/strong><\/td>([\S\s*]+?)<\/div>/'; $this->d ...

  9. c 语言练习__求到N的阶乘的和。

    #include <stdio.h> /* 题目如下 * S = 1 + 2! + 3! + ... + N! */ int main(int argc, char *argv[]) { ...

随机推荐

  1. 拥抱ARM妹纸第二季 之 第二次 约会需要浪漫,这么大灯泡怎么弄?

    终于轮到俺的小穆出场啦.有请能让太阳也为之暗淡的小穆闪亮登场-,鼓掌吧,欢呼吧!-- ♪♪ We can burn brighter Than the sun ~~~ ♪♪ “谢谢---“ 唱的太棒啦 ...

  2. MySQL主从同步报Client requested master to start replication from position

    数据库版本:5.6.16 测试环境MySQL 主从,数据库被人重启,忘记开启start slave,导致主从失效,停了一天的数据没有追上. 查看从库的数据库状态:show   slave   stat ...

  3. Input event驱动

    Input event驱动 Linux 专门对输入设备. 键盘,鼠标,手柄,触摸屏.按键.封装一个类驱动. 主要统一与应用程序接口.这一类的设备结点都是在/dev/input/eventn( 0< ...

  4. JS类库函数收集中....

    实现string的substring方法 方法一:用charAt取出截取部分 String.prototype.mysubstring=function(beginIndex,endIndex){ v ...

  5. Linux C 文件与目录1 创建目录

    linux C    创建目录 创建目录函数:mkdir 函数原型:int mkdir(char * pathname , mode_t mode); pathname字符指针是表示需要创建的目录路径 ...

  6. cocos2dx中的假动作,又称动作回调函数

    1.动作与动画的区别 动作是:定时器+属性的改变,是帧循环的累积效应 动画是:帧图片的播放效果,我们知道电影的播放就是快速播放的胶片,这就是动画的原理 2.假动作:又称动作回调函数 四大类假动作: c ...

  7. Excel取消保护密码

    Excel表被保护了, 如果没有密码, 可通过以下宏代码查看 (Office 2013已测) Option Explicit Public Sub AllInternalPasswords()' Br ...

  8. JSTL标签总结

    一.JSTL简介: 1.JSP标准标签库JSTL(JSP Standard Tag Library)是一个JSP标签集合,它封装了JSP应用的通用核心功能. 2.JSTL支持通用的.结构化的任务.比如 ...

  9. C#之多态

    多态是面向对象编程中三大机制之一,其原理建立在"从父类继承而来的子类可以转换为其父类"这个规则之上,换句话说,能用父类的地方,就能用该类的子类.当从父类派生了很多子类时,由于每个子 ...

  10. w3c_html_study_note_5.26

    xhtml+css 正确的说法 “DIV+CSS”叫法将网页制作者引入两大误区 [误区一]网页中用了Table,页面就不标准,甚至觉着用Table丢人,Table成为了判定页面是否标准的关键点. [误 ...