C++笔记2

1.Josephus数小孩

#include <iostream>
#include<stdlib.h>
using namespace std;
typedef struct Node
{
    int data;
    struct Node *next;
}Node,*List;
class Ring//环链表
{
private:
    List First;
    int Count;
    int Current;
    //List Begin;
public:
    void Print();
    void Clear(){};
    void Creatlist(int n,int m,int z);
    void Pivot();
};
void Ring::Creatlist(int n,int m,int z)
{
    List p;
    int i;
    First=(Node*)malloc(sizeof(Node));
    if(!First)
    {
        cout<<"memory allocation error!\n";
        return ;
    }
    First->data=1; First->next=First;
    for(i=n;i>1;--i)
    {
        p=(Node*)malloc(sizeof(Node));
        if(!p)
        {
            cout<<"memory allocation error!\n";
            return;
        }
        p->data=i; p->next=First->next; First->next=p;
    }
    Count = n;
    Current = m;
    if(z<1)return;
    for(int j = 0;j<z;j++)
    {
        First=First->next;
    }
}
void Ring::Print()
{
    List p=First;
    do
    {
        cout<<p->data<<" ";
        p=p->next;
    }while(p!=First);
    cout<<endl;
}
void Ring::Pivot()
{
    Node* p=First,*pre=NULL;
    int i,j;
    for(i=0;i<Count-1;++i)
    {
        for(j=1;j<Current;++j)
        {
            pre=p;
            p=p->next;
        }
        cout<<"出列的人是"<<p->data<<endl;
        pre->next=p->next; free(p);
        p=pre->next;
    }
    cout<<"The winner is "<<p->data<<endl;
}
class Josephus
{
private:
    int Boynumber;//孩子数量
    int Beginpos;//开始位置
    int Inteval;//间隔
    Ring Head;
public:
    void Inital();//初始化
    void Getwinner();//获得胜利者
    void Output();
};
void Josephus::Inital()
{
    cout<<"Input the Boynumber , Inteval and Beginpos:";
    cin>>Boynumber>>Inteval>>Beginpos;
    if(Inteval < 2)Inteval = 2;
    Head.Creatlist(Boynumber,Inteval,Beginpos);
}
void Josephus::Getwinner()
{
    Head.Pivot();
}
void Josephus::Output()
{
    Head.Print();
}
int main()
{
Josephus jose;
jose.Inital();
jose.Output();
jose.Getwinner();
return 0;
}

2.静态成员

#include<iostream>
using namespace std;
class Student
{
    static int num;
     int id;
public:
    Student()
    {
        num++;
    }
    ~Student()
    {
        num--;
    }
    int getid()//普通函数可以操作普通成员和静态成员,静态函数只能操作静态成员 
    {
        id=0;
        return num;
    }
     int getnum()
    {
        return num;
    }
};
int Student::num=0;
int main()
{
    Student t1;
    Student t2;
    Student *t3=new Student;
    cout<<"student num1="<<t2.getnum()<<endl;
    delete t3;
    cout<<"student num2="<<t2.getnum()<<endl;
}

友元1(friend)

#include<iostream>
using namespace std;
class Student
{
     int m_id;
public:
    Student(int id)
    {
        m_id=id;
        
    }
    friend void test(Student t);//友元(突破封装) 
};
void test(Student t)
{
    cout<<"id="<<t.m_id<<endl;
     
}
int main()
{
    Student t1(10);
    test (t1);
}

友元2

#include<iostream>
using namespace std;
class Student
{
     int m_id;
public:
    Student(int id)
    {
        m_id=id;
        
    }
    friend class A;//友元(突破封装) 
};

class A
{
public:
    void test(Student t)
    {
        cout<<"id="<<t.m_id<<endl;
    }
     
};
int main()
{
    Student t1(10);
    A a;
    a.test (t1);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. big three 带有指针的class, 拷贝构造,拷贝赋值和析构函数必须自己写(深拷贝)。编译器给的那...
    竹林柳岸阅读 1,355评论 0 0
  • 一、析构函数的主要作用就是:释放资源,避免内存泄漏。 如果类里面只用到的基本类型,如int char dou...
    irishehe阅读 1,765评论 0 0
  • 第一天 一.内联函数(inline) 函数调用的时候需要建立栈内存环境,进行参数传递,并产生程序执行转移,这些工作...
    陈果123阅读 4,826评论 0 1
  • 话说江东多磨难,一波未平一波起。三定江南的周玘虽然对东晋王朝的建立居功至伟,却没有得到重用,反而受到了司马睿的猜忌...
    寒七琪阅读 1,850评论 0 0
  • 感谢我十九岁的小尾巴遇见了你 ^ 我爱你就这么简单 生日愿望就是家人平安健康和你一直一直走下去 因为我已经离不开你...
    Reachel阅读 1,950评论 0 1

友情链接更多精彩内容