编程题-函数模板

一、编写一个函数模板,求数组中的最大元素,并写出调用此函数模板的完整程序,使得函数调用时,数组的类型可以是整数也可以是双精度类型。

cpp 复制代码
#include<iostream>
using namespace std;
template <class Type>             //函数模板
Type max(Type *Array,int size)
{ int i,j=0;
      for (i=1;i<size-1;i++)
	    if (Array[i]>Array[j])
	    { j=i; } 
      return  Array[j];
}
int main()
{ int intArray[]={11,12,13,14,7,8,9};
      double doubleArray[]={11.2,12.3,13.2,14.5,14.8,8.7,9.3};
      cout<<max(intArray,7)<<endl;
      cout<<max(doubleArray,7)<<endl;
return 0;
}

二、编写一个函数模板,使用冒泡排序将数组内容由小到大排列并打印出来,并写出调用此函数模板的完整程序,使得函数调用时,数组的类型可以是整数也可以是双精度型。

cpp 复制代码
#include <iostream>
using namespace std;
template <class Type>
void sort(Type *Array,int size)
{ int i,j;
  for (i=0;i<size-1;i++)
	for (j=0;j<size-i-1;j++)
	  if (Array[j]>Array[j+1])
	  { Type temp= Array[j];
	    Array[j]=Array[j+1];
	    Array[j+1]=temp;
	  }  
for (i=0;i<=size-1;i++)
    cout<<Array[i]<<" ";
  cout<<endl;
}
int main()
{ int intArray[]={11,12,13,14,7,8,9};
  double doubleArray[]={11.2,12.3,13.2,14.5,14.8,8.7,9.3};
  sort(intArray,7);
  sort(doubleArray,7);
  return 0;
}

三、建立一个用来实现求三个数和的类模板(将成员函数定义在类模板的内部), 并写出调用此类模板的完整程序。在类模板外定义各成员函数。

cpp 复制代码
#include<iostream>
using namespace std;
template<typename T>          //模板声明,其中为T类型参数
class Sum{                    //类模板名为Sum
  public:
    Sum(T a,T b,T c);         //声明构造函数的原型
    T add();                //声明成员函数add的原型
  private:
T x,y,z;
};
template <typename T>         //模板声明
Sum<T>::Sum(T a, T b,T c)     //在类模板体外定义构造函数
{ x=a;  y=b;  z=c;
}
template <typename T>         //模板声明
T Sum<T>:: add()             //在类模板体外定义成员函数add,返回类型为T
{ return x+y+z;
}
int main()
{ Sum<int> s1(3,7,9);         //用类模板定义对象s1,此时T被int替代
  Sum<double> s2(12.34,56.78,67.89); 
//用类模板定义对象s2,此时T被double替代
  cout<<"三个整数的和是:"<<s1. add()<<endl;
  cout<<"三个双精度数的和是:"<<s2. add()<<endl;
  return 0;
}
相关推荐
小龙报4 分钟前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
小武编程7 分钟前
基于JL700N可视化SDK的MAC地址应用
c语言·tws耳机·杰理jl700n
乌萨奇也要立志学C++12 分钟前
【洛谷】BFS 求解最短路:从马的遍历到迷宫问题的实战解析
算法·宽度优先
石去皿16 分钟前
【嵌入式就业6】计算机组成原理与操作系统核心机制:夯实底层基础
c++·面试·嵌入式
王老师青少年编程17 分钟前
2024年信奥赛C++提高组csp-s初赛真题及答案解析(完善程序第1题)
c++·题解·真题·初赛·信奥赛·csp-s·提高组
老鼠只爱大米21 分钟前
LeetCode经典算法面试题 #46:全排列(回溯、交换、剪枝等五种实现方案详细解析)
算法·leetcode·剪枝·回溯·全排列·stj算法
Dovis(誓平步青云)34 分钟前
《滑动窗口算法:从 “暴力遍历” 到 “线性高效” 的思维跃迁》
运维·服务器·数据库·算法
一只小小的芙厨1 小时前
AT_tkppc3_d 巨大チェスボード 题解
c++·题解
我在人间贩卖青春1 小时前
C++之继承与派生类的关系
c++·向上造型·向下造型
Trouvaille ~1 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层