zoukankan      html  css  js  c++  java
  • 笔记

    用c的方式实现栈
    用C++数据抽象的方式实现栈
    #include<stdio.h>


    struct
    struct Stack
    {
    };
    void StackInit(struct Stack* stack)
    {
    stack->head=NULL;
    stack->size=0;
    }
    void StackPush(structStack*stack,const int data)
    {
    struct Link* node;
    node=(struct Link*)malloc(sizeof(struct Link));
    assert(node!=NULL);
    node->data=data;
    node->next=stack->head;
    stack->head=node;
    ++stack->size;
    }


    int StackEmpty(struct Stack* stack)
    {
    return (stack->size==0);
    }
    int StackPop(struct Stack* stack,int* data)
    {
    if(StackEmpty(stack))
    {
    return 0;
    }
    struct Link* tmp=stack->head;

    *data=stack->head->data;
    stack->head=stack->head->next;
    free(tmp);
    --stack->size;
    return 1;
    }
    void StackCleanup(struct Stack* stack)
    {
    struct Link* tmp;
    while(stack->head)
    {
    tmp=stack->head;
    stack->head=stack->head->next;
    free(tmp);
    }
    stack->size=0;
    }
    int main(void)
    {
    struct Stack stack;
    StackInit(&stack);
    int i;
    for(i=0;i<5;i++)
    {
    StackPush(&stack,i);
    }
    while(!StackEmpty(&stack))
    {
    StackPop(&stack,&i);
    print("%d",i);
    }
    printf("\n");
    return 0;
    }
    一,运算符重载
    成员函数重载
    非成员函数重载(友元)
    运算符重载规则
    重载各种运算符
    体现了C++的可扩充性
    运算符重载仅仅是语法上的方便,是一种函数调用的方式
    运算符重载,本质上是函数重载
    不要滥用重载
    只有在涉及的代码更容易写,尤其是更容易读时才有必要重载
    普通函数重载即可
    重载格式:
    函数类型 operator 运算符(参数表)
    成员函数定义:
    函数类型 类名::运算符(参数表)
    {
    函数体;
    }
    #ifndef _COMPLEX_H_
    #define _COMPLEX_H_
    class Complex
    {
    public:
    Complex(int real,int imag);
    Complex();
    ~Complex();

    Complex& Add(const Complex& other);
    void Display() const;

    Complex operator+(const Complex& other);
    private:
    int real_;
    int imag_;
    };
    #endif//_COMPLEX_H_

    #include"Complex.h"
    #include<iostream>
    using namesapce std;

    Complex::Complex(int real,int imag):real_(real),imag_(imag)
    {


    }

    Complex::Complex()
    {
    }
    Complex::~Complex()
    {
    }
    Complex& Complex::Add(const Complex& other)
    {
    real_+=other.real_;
    imag_+=other.real_;
    return *this;
    }

    Complex Complex::operator+(const Complex& other)
    {
    int r=real_+other.real_;
    int i=imag_+other.imag_;

    return *this;
    }
    void Complex::Display() const
    {
    cout<<real_<<"+"<<imag_<<"i"<<endl;
    }

    #include"Complex.h"
    int main(void)
    {
    Complex c1(3,5);
    Complex c2(4,6);

    //c1.Add(c2);
    //c1.Display();
    Complex c3=c1+c2;
    return 0;
    }

     

  • 相关阅读:
    Jenkins学习记录(三)
    Jenkins学习记录(二)
    并发编程
    黏包及解决方法
    socket通信,三次握手,四次挥手
    异常处理
    元类与魔法方法
    封装方法与多态
    组合与封装
    继承
  • 原文地址:https://www.cnblogs.com/herizai/p/3092589.html
Copyright © 2011-2022 走看看