c++模板

1. 问题描述

分别找出一组int型数据,一组double型数据,一组字符数组型数据的最大值并输出。main函数代码如下所示:

int main()
{
	int a[] = { 5,4,6,2,0,12,8,7,1,3 };
	double b[] = { 1.1,3.3,5.5,6.6,4.4,7.7,9.9,8.8,0.0,2.2 };
	const char* c[] = { "Huaian","Yancheng","Yangzhou","Nanjing","Suzhou" };
	cout << max<int>(a, sizeof(a) / sizeof(int)) << endl;
	cout << max<double>(b, sizeof(b) / sizeof(double)) << endl;
	cout << max(c, 5) << endl;//调用char* max(const char* a[], int n)
	return 0;
}

2、分析

double型数据与int型数据考虑用模板写,字符数组单独定义一个函数供其调用。

3、代码实现

#include<iostream>
#include<cstring>
using namespace std;
template<class	T>//模板
T max(T a[], int n)
{
	T m = a[0];
	for (int i = 1; i < n; i++)
	{
		if (a[i] > m)
		{
			m = a[i];
		}
	}
	return m;
}
char* max(const char* a[], int n)
{
	char* str = new char[50];
	strcpy_s(str, strlen(a[0]) + 1, a[0]);
	for (int i = 1; i < n; i++)
	{
		if (strcmp(a[i], str) > 0)
		{
			strcpy_s(str, strlen(a[i]) + 1, a[i]);
		}
	}
	return str;
}
int main()
{
	int a[] = { 5,4,6,2,0,12,8,7,1,3 };
	double b[] = { 1.1,3.3,5.5,6.6,4.4,7.7,9.9,8.8,0.0,2.2 };
	const char* c[] = { "Huaian","Yancheng","Yangzhou","Nanjing","Suzhou" };
	cout << max<int>(a, sizeof(a) / sizeof(int)) << endl;
	cout << max<double>(b, sizeof(b) / sizeof(double)) << endl;
	cout << max(c, 5) << endl;//调用char* max(const char* a[], int n)
	return 0;
}

第一篇博客,写句话纪念下,希望未来的自己看到后能想起一些值得怀念与自豪的事情:

永远相信美好的事情即将发生
(๑•̀ㅂ•́)و✧

posted @   zi_mei  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示