C++构造、析构、继承、多态--一道笔试题都考到了

#include <stdio.h>

class A
{
public:
    A()
    {
        printf("A constrution.\n");
     }
    ~A()
    {
        printf("A deconstrution.\n");
    }
    void funA();
   virtual  void funB();
};

 void A::funA()
{
        printf("A::funA ...\n");
 }    
    
void A::funB()
{
        printf("A::funB ...\n");
}

class B : public A
{
public:
    B()
    {
        printf("B constrution.\n");
     }
    ~B()
    {
        printf("B deconstrution.\n");
    }
    void funA();
     virtual  void funB();
};

 void B::funA()
{
        printf("B::funA ...\n");
 }    
    
void B::funB()
{
        printf("B::funB ...\n");
}

void main()
{
    A *a = new B();
    B b;
    a->funA();
    a->funB();
    b.funA();
    b.funB();
    delete a;
}


 

写出输出结果:(呵呵,顺便复习一下g++的编译的几个步骤)





  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
#region 1:一列数的规则如下: 1、1、2、3、5、8、13、21、34......求第30位数是多少, 用递归算法实现。 //int n = FindNum(30); //Console.WriteLine(n); //Console.ReadKey(); #endregion #region 2:有一个3*4矩阵,输出最大元素的值,及其所在的行号和列号, int a[3][4]={{1,2,3,4},{9,8,7,6}, {-10,10,-5,2}}。 //int[,] a = { { 1, 2, 3, 4 }, { 9, 8, 7, 6 }, { -10, 10, -5, 2 } }; //Max1(a); //Console.ReadKey(); #endregion #region 3:实现二分法查找,int a[8] = {3,12,24,36,55,68,75,88},查找24需要几次查找出来。 //int[] a = { 3,12,24,36,55,68,75,88 }; //int value = 24; //Select(a, value); //Console.ReadKey(); #endregion #region 4:实现冒泡排序, int[] array = { 23, 45, 16, 7, 42 }。 //int[] array = { 23, 45, 16, 7, 42 }; //Sort(array); //foreach(int n in array) //{ // Console.WriteLine(n); //} //Console.ReadKey(); #endregion #region 5:求出0-1000中能被7整除的数,并计算输出每五个数的和。 //int sum = 0;//每五个数的和 //int count = 0;//计算个数 //for(int i=1;i<=1000;i++) //{ // if(i%7==0) // { // count++;//个数加一 // sum = sum + i; // if (count % 5 == 0) // { // Console.WriteLine(sum); // sum = 0; // } // } //} //Console.WriteLine("1 - 1000中一共有{0}个数被7整除", count); //Console.ReadKey(); #endregion #region 6:编写一个类,其中包含一个排序的方法 Sort(), 当传入的是一串整数,就按照从小到大的顺序输出 如果传入的是一个字符串,就将字符串反序输出。 //SortAndReverse sa = new SortAndReverse(); //string intput = "woaini"; //Console.WriteLine(sa.Sort(intput)); //Console.ReadKey(); #endregion #region 7:编写一个矩形类,私有数据成员为矩形的长(len)和宽(wid),无参构造函数将len和wid设置为0,有参构造函数设置len和wid的值;另外,类还包括矩形的求周长、求面积、取矩形的长度、取矩形的宽度、修改矩形的长度和宽度为对应的形参值等公用方法。 //Rectangular rt = new Rectangular(); //rt.Len = 10; //rt.Wid = 15; //Console.WriteLine(rt.Area()); //Console.ReadKey(); #endregion #region 8:编写一个控制台应用程序,接收一个长度大于3的字符串,完成 下列功能:1 输出字符串长度。  2 输出字符串中第一个出现字母a的位置。  3 在字符串的第3个字符后面插入子串“hello”,输出新字符串。 4 将字符串“hello”替换成“me”,输出新字符串。  5 以字符“m”为分隔符,将字符串分离,并输出分离后的字符串。) //Console.WriteLine("请输入一个长度大于3的字符串:"); //string str= Console.ReadLine(); ////输出字符串长度 //Console.WriteLine("字符串长度为:{0}", str.Length); ////输出字符串中第一个出现字母a的位置 //if (str.IndexOf("a") == -1) //{ // Console.WriteLine("未找到字母a"); //} //else //{ // Console.WriteLine("第一个出现字母a的位置是{0}", str.IndexOf("a")); //} ////在字符串的第3个字符后面插入子串“hello”,输出新字符串。 //str = str.Insert(3, "hello"); //Console.WriteLine(str); ////将字符串“hello”替换成“me”,输出新字符串。 //str = str.Replace("hello", "me"); //Console.WriteLine(str); ////以字符“m”为分隔符,将字符串分离,并输出分离后的字符串 //string[] str1 = str.Split('m'); //Console.Write("分离后的字符串为:"); //foreach(string n in str1) //{ // Console.Write(n + " "); //} //Console.ReadKey(); #endregion
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一马途追

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值