2、>intmain(){intc,Num_space=0,Num_tab=0,Num_enter=0;while((c=getchar())!=EOF){switch(c){case'':Num_space++;break;case't':Num_tab++;break;case'':Num_enter++;break;}}printf("ThenumberofSpaceis%d",Num_space);printf("ThenumberofTabis%d",Num_tab);printf("Then
3、umberofEnteris%d",Num_enter);return0;}3、编写一个将输入复制到输出的程序,并将其中连续的多个空格用一个空格代替。4、编写一个程序,统计输入的行数、单词数与字符数。5、编写一个程序,统计各个数字、空白符(包括空格符、制表符及换行符)以及所有其他字符出现的次数。6、重写标准库中的求幂函数:intpow(intx,inty)。7、编写一个程序,删除每个输入行末尾的空格。8、编写函数reverse(),将字符串s中的字符顺序颠倒过来。(附加:尝试用递归的思想来实现reverse)
4、9、编写一个删除C语言程序中所有的注释语句、要正确处理带引号的字符串与字符常量。在C语言程序中,注释不允许嵌套。(附加)10、编写一个程序,查找C语言程序中的基本语法错误,如圆括号、方括号以及花括号不配对等。要正确处理引号(包括单引号、双引号)、转义字符序列与注释。(附加)第二章类型、运算符与表达式&&第三章控制流1、编写atoi函数,将字符串s(eg:”123”)转换为相应的整型数(eg:123)原型:intatoi(chars[])2、编写函数htois(s),把由十六进制数字组成的字符串(包含可选的前缀0x
5、或0X)转换为与之等价的整型值。字符串中允许包含的数字包括:0~9、a~f、A~F。3、编写一个程序,将字符串s1中任何与字符串s2中字符匹配的字符都删除。函数原型:voidsqueeze(chars1[],chars2[])4、编写如下按位操作函数:(1)voidsetbit(unsignedx,intn);(2)voidclearbit(unsignedx,intn);(3)intgetbit(unsignedx,intn);(4)intbitcount(unsignedx);//统计x中值为1的二进制位数5
6、、编写一个函数setbits(x,p,n,y),该函数返回对x执行下列操作后的结果值:将x中从第p位开始的n个(二进制)位设置为y中最右边n位的值,x的其余各位保持不变。函数原型:unsignedsetbits(unsignedx,intp,intn,unsignedy);6、编写一个函数invert(x,p,n),该函数返回对x执行下列操作后的结果值:将x中的第p位开始的n个(二进制)位求反(即1变成0,0变成1),x的其余各位保持不变。函数原型:unsignedinvert(unsignedx,intp,in
7、tn);(选做!)7、编写一个函数rightrot(x,n),该函数返回将x循环右移(即从最右端移出的位将从最左端移入)n(二进制)位后所得到的值。函数原型:unsignedrightrot(unsignedx,intn);(选做!)8、实现折半查找函数intbinsearch(intx,intv[],intn),该函数用于判定已排序的数组v中是否存在某个特定的值x。数组v的元素必须以升序排序。如果v中包含x,则该函数返回x在v中的位置(介于0~n-1之间的一个整数);否则,该函数返回-1。9、编写一个函数voi
8、descape(chars[],chart[]),将字符串t复制到字符串s中,并在复制过程中将换行符、制表符等不可见字符分别转换为、t等相应的可见的转义字符序列。要求使用switch语句。再编写一个具有相反功能的函数voidunescape(chars[],chart[]),在复制过程中将转义字符序列转换为实际字符。10、编写voiditoa(intn,chars[