用栈实现逆序输出键盘输入
2009-08-17 15:38
246 查看
#include"stdlib.h" #include"stdio.h" typedef char StackEntry; typedef struct node { //链栈的结点结构 StackEntry item; //栈的数据元素类型 struct node *next; //指向后继结点的指针 }NODE; typedef struct stack{ NODE *top; }STACK; //初始化栈 void InitStack(STACK *S) { S->top=NULL; } //入栈 void Push(STACK *S,StackEntry item) { NODE* p; p=(NODE*)malloc(sizeof(NODE)); if (!p) exit(0); else { p->item=item; p->next=S->top; S->top=p; } } //是否为空栈 int StackEmpty(STACK S) { if (S.top==NULL) return true; else return false; } //出栈 void Pop(STACK*S, StackEntry *item) { NODE *p; if (StackEmpty(*S)) exit(0); else { *item=S->top->item; p=S->top; S->top=p->next; free(p); } } void ReverseRead( ) { STACK S; //定义一个栈结构S char ch; InitStack(&S); //初始化栈 while ((ch=getchar())!='\n') //从键盘输入字符,直到输入换行符为止 Push(&S ,ch); //将输入的每个字符入栈 while (!StackEmpty(S)) { //依次退栈并输出退出的字符 Pop(&S,&ch); putchar(ch); } putchar('\n'); } void main(){ ReverseRead(); }
相关文章推荐
- 用栈实现逆序输出键盘输入
- 用栈实现逆序输出键盘输入
- 实现从控制台输入字符串,逆序打印输出
- C语言:用递归实现将输入的整数按逆序输出。如输入12345,则输出54321。
- 有键盘输入一个3位数,编程计算并输出它的逆序阿数
- 函数实现键盘输入整型数,将其转换成字符串输出。123456789 "123456789"
- JAVA基础 day21 字节流的输入和输出 字节流的缓冲区 (自己实现BufferedInputStream) 键盘输入 转换流的用法 改变标准输入输出设备 IO流操作的基本规律
- 万年历(实现从键盘输入1900年之后的任意的某年、某月,输出该月的日历)
- 三种算法实现:从键盘输入任意正整数,从低位到高位逐位输出各位数字
- 从易到难编写C++程序,(1)问题:把键盘输入的字符串逆序输出。
- 指针访问方式从键盘给数组 a[N]输入数据, 然后对元素值重新按逆序存放并输出
- 用递归实现输入一系列整数后逆序输出
- 输入k 实现链表每k项都逆序输出
- 记录从键盘输入的字符串,计算字符串的长度并用指针实现对字符串的逆向输出
- 编程实现由键盘输入一个字符后,在屏幕上输出该字符
- 七、输入输出系统:用锁实现输出、编写键盘驱动程序、环形输入缓冲区
- 从键盘输入一个整数,然后逆序输出
- 输入k 实现链表每k项都逆序输出
- java基础之IO流中实现对键盘和控制台的输入和输出以及写到文本文件
- 基于8051的扫描式键盘驱动和串并转换式显示编程实现人机I/O(键盘输入,数码管输出)