鱼C论坛

 找回密码
 立即注册
查看: 1991|回复: 2

结构体模板怎样作为函数参数

[复制链接]
发表于 2014-10-21 15:31:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
template <class T>
struct node{
    T *elem;
    int length;
    int MaxSize;
};

template <class T>
void InitStack(Stack<T> &S){
    S->elem = (T*)malloc(Size * sizeof(T));
    if(!S->elem)
        exit(0);
    S->length = 0;
    S->MaxSize = Size;
}
个人觉得是这么写,求大神解惑

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2014-10-21 21:46:38 | 显示全部楼层
  1. #include <iostream>
  2. #include <cassert>
  3. using namespace std;

  4. template <class T>
  5. struct Stack{
  6.         T *elem;
  7.         int length;
  8.         int MaxSize;
  9. };

  10. template <class T>
  11. void InitStack(Stack<T> &S, int size) {
  12.         S.elem = new T[size];
  13.         S.length = 0;
  14.         S.MaxSize = size;
  15. }

  16. template <class T>
  17. void DestroyStack(Stack<T> &S) {
  18.         if( S.MaxSize >0 )
  19.                 delete[] S.elem;
  20. }

  21. template <class T>
  22. void PushStack( Stack<T> &S, const T& e ) {
  23.         assert( S.length < S.MaxSize );
  24.         (S.elem)[S.length++] = e;
  25. }

  26. template <class T>
  27. T PopStack( Stack<T> &S ) {
  28.         assert( S.length > 0 );
  29.         return (S.elem)[--S.length];
  30. }

  31. int main() {
  32.         int i;
  33.         Stack<int> stack;
  34.         InitStack( stack, 20 );
  35.         for( i=0;i<10;++i )
  36.                 PushStack( stack, i );
  37.         for( i=0;i<10;++i )
  38.                 cout<<PopStack(stack)<<endl;
  39.         DestroyStack( stack );
  40. }


复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2014-10-23 11:30:40 | 显示全部楼层
楼上+1.               
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-15 10:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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