几道简单ACM题的解答----8
来源:互联网 发布:这两天网络怎么了 编辑:程序博客网 时间:2024/06/14 01:00
题目:
行编辑器Problem
一个简单的行编辑程序的功能是:接受用户从终端输入的程序或数据,并存入用户的数据区。
由于用户在终端上进行输入时,不能保证不出差错,因此,若在编辑程序中,“每接受一个字符即存入用户数据区”的做法显然不是最恰当的。较好的做法是,设立一个输入缓冲区,用以接受用户输入的一行字符,然后逐行存入用户数据区。允许用户输入出差错,并在发现有误时可以及时更正。例如,当用户发现刚刚键入的一个字符是错的时,可补进一个退格符"#",以表示前一个字符无效;
如果发现当前键入的行内差错较多或难以补救,则可以键入一个退行符"@",以表示当前行中@前面的字符均无效。
如果已经在行首继续输入'#'符号无效。
Input
输入一个多行的字符序列。但行字符总数(包含退格符和退行符)不大于250。
Output
按照上述说明得到的输出。
Sample Input
whli##ilr#e(s#*s)
outcha@putchar(*s=#++);
Sample Output
while(*s)
putchar(*s++);
我的答案:
#include<stdio.h>#include<string.h>int getline(char buffer[]);void dealWith(char buffer[]);void saveLine(char buffer[],char userData[]);int main(){char buffer[250];char userData[250];//char c;int i = getline(buffer);while(i - 1){dealWith(buffer);saveLine(buffer,userData);strcpy(buffer,"");i = getline(buffer);printf("%d\n",i);}/* while(c != '\n'){while((c = getchar()) != '\n')buffer[i++] = c;dealWith(buffer);saveLine(buffer,userData);} */printf("%s",userData);return 0;}int getline(char buffer[]){char c;int i = 0;while((c = getchar()) != '\n')buffer[i++] = c;buffer[i++] = '\n';buffer[i] = '\0';return i;}void del(char buffer[],int i){buffer[i] = '*';}void dealWith(char buffer[]){int j = 1;int i = 0;int k;printf("dealwith buffer\n");while(buffer[i] != '\n' && buffer[i] != '\0'){if(buffer[i] == '#'){del(buffer,i);puts(buffer);while(buffer[i - j] == '*'){printf("J++\n");j++;}putchar(buffer[i - j]);del(buffer,i - j);puts(buffer);j = 1;}if(buffer[i] == '@'){for(k = 0;k <= i;k++)del(buffer,k);}i++;}}void saveLine(char buffer[],char userData[]){int j = 0;int i = 0;printf("save buffer\n");printf("buffer is %s",buffer);while(buffer[i] != '\n' && buffer[i] != '\0'){if(buffer[i] != '*')userData[j++] = buffer[i++];elsei++;}userData[j] = '\0';printf("%s\n",userData);}//改成'*'
- 几道简单ACM题的解答----8
- 几道简单ACM题的解答----1
- 几道简单ACM题的解答----2
- 几道简单ACM题的解答----3
- 几道简单ACM题的解答----4
- 几道简单ACM题的解答----5
- 几道简单ACM题的解答----6
- 几道简单ACM题的解答----7
- 几道java题的解答
- 关于一笔画问题的简单解答ACM中的题(1)
- 几道算法解答
- 关于ACM练习第八题的思考和解答
- 哎,心碎博弈论,做了几道十分简单的。 ACM b博弈
- [编程题]确定两串乱序同构的几种解答方式
- 一些简单的acm题
- ACM数读问题的解答
- 几道浙大acm题代码
- 简单的几道算法题_AboutDP
- Java 线程池学习
- 掌握Ajax第2部分:使用JavaScript和Ajax发出异步请求
- myeclipse加载buiding workspace慢解决方案
- Android Application 和Webview 之间的交互
- Android 权限集合
- 几道简单ACM题的解答----8
- The FastCGI pool queue is full 的错误 解决
- 黑马程序员——反射
- 在 HTML 中显示 XML 数据
- 使用php的五个小技巧
- 关于Context []startup failed due to previous errors有效解决方式
- Java内存泄漏分析
- Android: ListView添加animation后,在animation播放过程中背景变为黑色背景的解决方法
- Android源码下载