博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【C++深度剖析教程40】使用数值型模板技术计算1+2+3+...+N的值
阅读量:1999 次
发布时间:2019-04-28

本文共 1226 字,大约阅读时间需要 4 分钟。

上一篇文章学习了数值型模板技术,并利用相关技术,实现了C++的数组类模板。点击文章查看上一篇文章:

本篇文章,继续利用模板技术来解决一个问题。

如果想求1+2+3+…+N的结果,有很多种方法。可以循环遍历,可以直接使用公式求解。但是他们都不是最快的方法,我们今天使用模板技术,来最快速的求出结果。

1、回顾

模板参数可以是数值型参数。也就是非类型参数。如下图所示:

在这里插入图片描述

我们可以像上面定义一个局部数组,但是却不能这样定义:

int n=10;func
();

上面这种写法就是错的!!!

实际上,不光是类型参数不能为数值型模板参数,下面几种情况也不能作为模板参数

  • 浮点数不能作为模板参数
  • 变量不能作为模板参数(上面的int n)
  • 类对象不能作为模板参数

实际上,数值型模板参数是必须在编译阶段被处理的单元,因此在编译阶段数值型模板参数必须被准确无误的确定。向上面的变量,类对象等,都是只有在运行的时候才能够被确定的,所以不能作为数值型模板的参数。

2、解决方法

如果想求1+2+3+…+N的结果,有很多种方法。可以循环遍历,可以直接使用公式求解。但是他们都不是最快的方法,我们今天使用模板技术,来最快速的求出结果。

先上代码,看看如何最快速求解:

#include 
#include
using namespace std;template< int N > //这里是数值型模板参数class Sum{
public: static const int VALUE = Sum
::VALUE + N; //这里是一个递归的过程};/* 递归过程的终止条件 */template< >class Sum < 1 >{
public: static const int VALUE = 1;};int main(){
cout << "1 + 2 + 3 + ... + 10 = " << Sum<10>::VALUE << endl; cout << "1 + 2 + 3 + ... + 100 = " << Sum<100>::VALUE << endl; return 0;}

上面的代码运行结果为:

在这里插入图片描述

很明显,结果完全正确!!!

那么为什么它是最快的方法呢?

首先,我们知道,数值型模板参数都是在编译阶段确定了的,所以,上述代码的VALUE实际上是在编译的时候,就已经确定好了值,最后直接调用这个值,就是计算结果。这肯定比任何计算都要快(这归功于编译器,编译器为我们做了很多事)。

本文参考狄泰软件学院相关课程

想学习的可以加狄泰软件学院群,
群聊号码:199546072

学习探讨加个人(可以免费帮忙下载CSDN资源):

qq:1126137994
微信:liu1126137994

转载地址:http://ibytf.baihongyu.com/

你可能感兴趣的文章
ffmpeg & mplayer & vlc 手册
查看>>
视频编解码学习之二:编解码框架
查看>>
Redis拓展篇----过期策略
查看>>
Redis学习拓展篇---保护Redis
查看>>
Golang源码学习----string包
查看>>
Go语言并发组件
查看>>
Go语言的并发模式
查看>>
Linux中如何优雅的删除被打开的文件
查看>>
从零开始学Linux内核-----从Unix到Linux
查看>>
Linux内核学习----进程管理
查看>>
linux内核学习-----进程调度
查看>>
算法实现----二分查找go语言实现
查看>>
简析STUN协议
查看>>
使用 Minidumps 和 Visual Studio .NET 进行崩溃后调试
查看>>
Debug 和 Release 编译方式的本质区别
查看>>
struts返回xml数据例子
查看>>
内存对齐详解
查看>>
秋招总结(一)-C++归纳
查看>>
秋招总结(三)-操作系统归纳
查看>>
进程间通信
查看>>