OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5762|回复: 5

请教大家一个数据结构中关于顺序栈的问题:实在不明白,望高手详解!握手……

[复制链接]

86

主题

417

帖子

0

精华

高级会员

Rank: 4

积分
781
金钱
781
注册时间
2013-2-20
在线时间
0 小时
发表于 2013-3-9 15:43:49 | 显示全部楼层 |阅读模式
  1.  //定义结构体-顺序栈 
  2. typedef struct SeqStack   
  3. {  
  4.     ElementType array[STACK_SIZE];  
  5.     ElementType top;  
  6. }SEQSTACK;  

    //情况1
      
  7. int main(void)  
  8. {  
  9.     SEQSTACK *pS;//定义一个指向结构体变量的指针      
  10.     pS = (SEQSTACK *)malloc(sizeof(SEQSTACK));  
  11.     if (pS == NULL)  
  12.     {  
  13.         return FALSE;  
  14.     }  
  15.   
  16.     InitStack(pS);//初始化   
  17.     ushStack(pS, 1);//压栈   
  18.     ushStack(pS, 2);  
  19.     ushStack(pS, 3);  
  20.     ushStack(pS, 4);  
  21.     ushStack(pS, 5);  
  22.   
  23.     TraStack(pS);//遍历栈   
  24.   
  25.     free(pS);//释放pS所占内存空间   
  26.   
  27.     return 0;  
  28. }  
  29.   
  30. //情况2 
  31. int main(void) 
  32. { 
  33.     SEQSTACK STK;//定义一个结构体类型的变量 
  34.     SEQSTACK *pS;//定义一个指向结构体变量的指针    
  35.     pS = &STK;//将结构体变量的地址赋给指针 
  36.  
  37.     //下面函数的参数使用pS和&STK是等效的 
  38.     InitStack(pS);//初始化   
  39.     ushStack(&STK, 1);//压栈 
  40.     ushStack(pS, 2); 
  41.     ushStack(&STK, 3); 
  42.     ushStack(pS, 4); 
  43.     ushStack(&STK, 5); 
  44.  
  45.     TraStack(pS);//遍历栈 
  46.  
  47.     return 0; 
  48. }   
  49.   
  50. //请问情况1和2有什么区别啊?   
  51. //是情况1好还是2好?为什么呢?   
  52. //注:情况1和2的运行结果是一样的。与问题无关的代码均省略!
乐于思考,敢于请教;问人不累,诲人不倦!本人CSDN博客:http://blog.csdn.net/dcx1205 学习嵌入式的同学不要错过啊!
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

34

主题

805

帖子

4

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1865
金钱
1865
注册时间
2011-3-29
在线时间
140 小时
发表于 2013-3-11 13:16:06 | 显示全部楼层
1、一个从堆分配空间,一个从程序栈分配空间。
2、无所谓啦,看你的需要。1能够节省内存栈,防止溢出,不过使用较麻烦,一不小心就容易内存泄漏。2相反。
业余程序玩家。
回复 支持 反对

使用道具 举报

86

主题

417

帖子

0

精华

高级会员

Rank: 4

积分
781
金钱
781
注册时间
2013-2-20
在线时间
0 小时
 楼主| 发表于 2013-3-15 10:22:57 | 显示全部楼层
回复【2楼】ofourme:
---------------------------------
谢了! 能留个QQ吗?我QQ198211588
乐于思考,敢于请教;问人不累,诲人不倦!本人CSDN博客:http://blog.csdn.net/dcx1205 学习嵌入式的同学不要错过啊!
回复 支持 反对

使用道具 举报

34

主题

805

帖子

4

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
1865
金钱
1865
注册时间
2011-3-29
在线时间
140 小时
发表于 2013-3-15 12:55:18 | 显示全部楼层
不留。有问题论坛上问。
多看书,很多C语言的电子书不错的。
业余程序玩家。
回复 支持 反对

使用道具 举报

86

主题

417

帖子

0

精华

高级会员

Rank: 4

积分
781
金钱
781
注册时间
2013-2-20
在线时间
0 小时
 楼主| 发表于 2013-3-15 16:40:35 | 显示全部楼层
嗯,不留也行 没事
但那个属于数据结构的书籍吧,有没好的?推荐几本瞧瞧……
乐于思考,敢于请教;问人不累,诲人不倦!本人CSDN博客:http://blog.csdn.net/dcx1205 学习嵌入式的同学不要错过啊!
回复 支持 反对

使用道具 举报

86

主题

417

帖子

0

精华

高级会员

Rank: 4

积分
781
金钱
781
注册时间
2013-2-20
在线时间
0 小时
 楼主| 发表于 2013-3-15 16:42:32 | 显示全部楼层
回复【4楼】ofourme:
---------------------------------
我又提问题了,有时间帮看看啊
乐于思考,敢于请教;问人不累,诲人不倦!本人CSDN博客:http://blog.csdn.net/dcx1205 学习嵌入式的同学不要错过啊!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-23 19:56

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表