C堆栈
C堆栈实现的表达式求值
//Luangeng
#include<stdio.h>
#include<conio.h>
#include<windows.h>
#define SIZE 100
char t[10][14]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,
0,1,1,0,1,1,1,0,1,1,1,1,1,0,
0,1,1,1,1,0,1,1,1,0,1,0,1,0,
0,0,0,1,0,0,1,0,1,0,0,1,1,0,
0,1,1,1,1,1,0,1,0,1,1,0,1,0,
0,1,0,1,0,1,0,1,1,1,0,1,0,0,
0,1,1,0,1,0,1,0,0,1,1,0,1,0,
0,1,0,1,1,1,0,1,1,1,1,1,0,0,
0,1,1,1,0,1,1,1,0,1,0,1,1,0,
0,0,0,0,0,0,0,0,0,0,0,0,0,0};
typedef struct { short x,y; short d; } step;
typedef struct { step *top,*base; } stack;
void gotoxy(int x,int y)
{
COORD cd;
cd.X = x;
cd.Y = y;
HANDLE hout=GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleCursorPosition(hout,cd);
}
void creat(stack *s)
{ s->base=(step *)malloc(SIZE*sizeof(step));
s->top=s->base;
if(!s->base) printf("failed !\n");
}
void push(stack *s,short a,short b,short c)
{ if(s->top>=(s->base+SIZE))
printf("stack full !..........");
else
{ s->top++;
s->top->x=a;
s->top->y=b;
s->top->d=c;
gotoxy(b,a);
printf("%c",1);
}
}
void pop(stack *s)
{ if(s->base==s->top) printf("\nunderflow....\n");
else { gotoxy(s->top->y,s->top->x); printf(" "); s->top--; }
}
int main()
{ stack path;
short i,j,k;
creat(&path);
for(i=1;i<=10;i++)
for(j=1;j<=14;j++)
{
gotoxy(j,i);
if(t[i-1][j-1]==0)
printf("%s","#");
else printf(" ");
}
k=1;
push(&path,2,2,4); t[1][1]=-1;
while(!(path.top->x==9&&path.top->y==13))
{ switch(path.top->d)
{
case 4:
path.top->d--;
if(t[path.top->x-2][path.top->y-1]==1)
{
t[path.top->x-2][path.top->y-1]=-1;
push(&path,path.top->x-1,path.top->y,4); k++;
}
break;
case 3:
path.top->d--;
if(t[path.top->x-1][path.top->y]==1)
{ t[path.top->x-1][path.top->y]=-1;
push(&path,path.top->x,path.top->y+1,4); k++;
}
break;
case 2:
path.top->d--;
if(t[path.top->x][path.top->y-1]==1)
{ t[path.top->x][path.top->y-1]=-1;
push(&path,path.top->x+1,path.top->y,4); k++;
}
break;
case 1:
path.top->d--;
if(t[path.top->x-1][path.top->y-2]==1)
{ t[path.top->x-1][path.top->y-2]=-1;
push(&path,path.top->x,path.top->y-1,4); k++;
}
break;
case 0: pop(&path); k--; break;
}
if(path.top==path.base)
{ gotoxy(17,1);
printf("No way out !!");
break;
}
sleep(5);
gotoxy(17,10); printf("step=%d; ",k);
}
system("pause");
}
C堆栈的更多相关文章
- 谈谈一些有趣的CSS题目(三)-- 层叠顺序与堆栈上下文知多少
开本系列,讨论一些有趣的 CSS 题目,抛开实用性而言,一些题目为了拓宽一下解决问题的思路,此外,涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉 ...
- History API与浏览器历史堆栈管理
移动端开发在某些场景中有着特殊需求,如为了提高用户体验和加快响应速度,常常在部分工程采用SPA架构.传统的单页应用基于url的hash值进行路由,这种实现不存在兼容性问题,但是缺点也有--针对不支持o ...
- JVM学习(2)——技术文章里常说的堆,栈,堆栈到底是什么,从os的角度总结
俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: 堆栈是栈 JVM栈和本地方法栈划分 Java中的堆,栈和c/c++中的堆,栈 数据结构层面的堆,栈 os层面 ...
- arcgis engine 中出现的内存堆栈溢出问题。
两种解决方案: 1.循环加载mxd文档的时候出现的堆栈溢出,解决办法是每次循环结束时清空FeatureLayer,感觉并不好,但是确实可以实现功能. 2.循环调取featureclass的search ...
- java 堆栈 理解
Java 中的堆和栈 堆和栈:分为数据结构的堆和栈以及内存中的堆和栈,两种理解应区分开. 数据结构中的堆: 堆实际上指的就是(满足堆性质的)优先队列的一种数据结构,第1个元素有最高的优先权. 堆性质: ...
- python列表模拟堆栈和队列
对列特点:先进先出.后进后出 用列表insert.pop模拟进队出队: >>> l = [] >>> l.insert(0,'p1') >>> l ...
- GDB调试汇编堆栈过程分析
GDB调试汇编堆栈过程分析 分析过程 这是我的C源文件:click here 使用gcc - g example.c -o example -m32指令在64位的机器上产生32位汇编,然后使用gdb ...
- 20145212——GDB调试汇编堆栈过程分析
GDB调试汇编堆栈过程分析 测试代码 #include <stdio.h> short val = 1; int vv = 2; int g(int xxx) { return xxx + ...
- C和指针 第十七章 经典数据类型 堆栈 队列 二叉树
堆栈: // // Created by mao on 16-9-16. // #ifndef UNTITLED_STACK_H #define UNTITLED_STACK_H #define TR ...
- gdb调试汇编堆栈过程的学习
gdb调试汇编堆栈过程的学习 以下为C源文件 使用gcc - g code.c -o code -m32指令在64位的机器上产生32位汇编,然后使用gdb example指令进入gdb调试器: 进入之 ...
随机推荐
- WPF中实现
计算类的封装 using System; using System.Collections.Generic; using System.Linq; using System.Text; namespa ...
- paper 90:人脸检测研究2015最新进展
搜集整理了2004~2015性能最好的人脸检测的部分资料,欢迎交流和补充相关资料. 1:人脸检测性能 1.1 人脸检测测评 目前有两个比较大的人脸测评网站: 1:Face Detection Data ...
- VS2013中的快捷键
在VS2012中Ctrl+E+D 是对齐代码,然而在VS2013中变成了Ctrl+K+F #region的快捷键 Ctrl+K+S /// <summary> 快捷键 先写好函数或方法,然 ...
- springmvc+spring+mybatis分页查询实例版本1,ver1.0
无聊做做看看,几乎没有怎么仔细做过这方面的,总是以为很简单,想想就会,实际做起来结合工作经验感觉还是挺有收获的,可以用在自己的项目上 第一版本思路:框架使用ssm,这个无所谓,采用分页语句查询指定页面 ...
- vim多行缩进的方法
在visual模式下选中要缩进的行,然后按>
- web标准
仔细看看所有的前端招聘要求,几乎所有的都要求对web标准有深刻的理解. web标准,是一系列标准的集合.对前端来说,因为网页是由结构.表现和行为组成.对应的就有结构化标准语言,主要包括XHTML和XM ...
- SQL 基础语法(创建表空间、用户、并授予权限、数据的增删改查) --(学习笔记)[转]
--创建表空间 名:lyayzh_test create tablespace lyayzh_test --创建表数据文件 名:lyayzh_test_data.dbf 必须以dbf为后缀 dataf ...
- Elasticsearch多索引
在Elasticsearch中,一般的查询都支持多索引.只有文档API或者别名API等不支持多索引操作,因此本篇就翻译一下多索引相关的内容. 首先,先插入几条数据: $ curl -XPOST lo ...
- dota BP练习工具开发:一个C/S多用户程序
首发:个人博客,更新&纠错&回复 客户端采用C#开发,服务器使用java开发,通信方式为socket. 1.首先决定交互协议 客户端指令协议: getgames:要求服务端发送game ...
- redis 笔记06 发布与订阅、事务、慢查询日志、监视器
发布与订阅 1. 服务器状态在pubsub_channels字典保存了所有频道的订阅关系:SUBSCRIBE命令负责将客户端和被订阅的频道关联到这个字典里面,而UNSUBSCRIBE命令则负责 解除客 ...