当前位置: 首页 > news >正文

实习冲刺Day17

算法题

x的平方根

69. x 的平方根 - 力扣(LeetCode)

class Solution {
public:int mySqrt(int x) {long left = 0,right = x;//定义左右边界//数值取的大longlong类型while (left < right) {long mid = (right-left+1)/2+left;//定义中间节点if ((mid * mid )<= x) {//如果中间的平方小于x,那中间值左边的整体也小left = mid;} else {//如果中间值的大与x,那中间值的右边整体都大于x,right移动right = mid - 1;}}return (int)left;//返回left}
};

基础知识

如何使用函数模板和类模板? 

函数模版

函数模板可以重载,只要它们的形参表或类型参数表不同即可。

在有多个函数和函数模板名字相同的情况下,编译器如何处理,

  1. 先找参数完全匹配的普通函数(非由模板实例化而得的函数)。
  2. 再找参数完全匹配的模板函数。
  3. 再找实参数经过自动类型转换后能够匹配的普通函数。
  4. 上面的都找不到,则报错。
#include<iostream>
template <class 类型参数1,class 类型参数2, ……>
返回值类型 模板名(形参表) {函数体
};

求两数之和

#include<iostream>
using namespace std;
template<class T>
//计算两数之和
T sum(T a, T b) {T c = a + b;return c;}
int main() {int a = 10, b = 20;cout << sum(a, b) << endl;//自动转成int类型double c = 1.2, d = 2.3;cout << sum(c, d) << endl;//自动转成double类型
}

编译器自动生成函数

int sum(int a, int b) {int c = a + b;return c;}

类模版

在定义类的时候,加上一个/多个类型参数。在使用类模板时,指定类型参数应该如何替换成具体类型,编译器据此生成相应的模板类。

同一个类模板的两个模板类是不兼容的: 

编译器由类模板生成类的过程叫类模板的实例化。由类模板实例化得到的类,叫模板类。

template <class 类型参数1,class 类型参数2,……> //类型参数表
class 类模板名
{成员函数和成员变量
};

模板的优点是什么?

优点:

  1. 代码重用:减少了代码的冗余性。
  2. 类型安全:类型检查的时候更容易捕获错误
  3. 灵活性:模板提供了极高的灵活性,因为它们可以在任何支持所需操作的数据类型上使用。这包括用户定义的类型和STL(Standard Template Library)容器等内置类型。
  4. 性能:由于模板在编译时生成特定类型的代码,因此它们通常比使用虚函数或函数指针的方法更快。此外,由于类型信息在编译时是已知的,编译器可以进行优化。
  5. 抽象:模板提供了一种抽象机制,使得程序员可以专注于算法本身,而不是关注数据类型的具体实现。这有助于保持代码的清晰和简洁。
http://www.lryc.cn/news/480037.html

相关文章:

  • 我自己nodejs练手时常用的一些库基础用法
  • 岛屿数量问题
  • 智能制造基础- TPM(全面生产维护)
  • C++学习笔记----11、模块、头文件及各种主题(一)---- 模板概览与类模板(4)
  • 【力扣热题100】[Java版] 刷题笔记-160. 相交链表
  • 多线程和线程同步复习
  • 贝式计算的 AI4S 观察:使用机器学习对世界进行感知与推演,最大魅力在于横向扩展的有效性
  • 容器化技术入门:Docker详解
  • 基于SSM(Spring + Spring MVC + MyBatis)框架的药房管理系统
  • 在服务器里安装2个conda
  • web安全漏洞之ssrf入门
  • 《NoSQL 基础知识总结》
  • 高校宿舍信息管理系统小程序
  • 2.索引:MySQL 索引分类
  • sklearn红酒数据集分类器的构建和评估
  • 【IC验证面试常问-4】
  • 【数据集】【YOLO】【目标检测】交通事故识别数据集 8939 张,YOLO道路事故目标检测实战训练教程!
  • 书生浦语第四期基础岛L1G4000-InternLM + LlamaIndex RAG 实践
  • 基于ViT的无监督工业异常检测模型汇总
  • 数据库管理-第258期 23ai:Oracle Data Redaction(20241104)
  • 运放进阶篇-多种波形可调信号发生器-产生方波-三角波-正弦波
  • CSS中的变量应用——:root,Sass变量,JavaScript中使用Sass变量
  • WPF+MVVM案例实战与特效(二十八)- 自定义WPF ComboBox样式:打造个性化下拉菜单
  • 速盾:怎么使用cdn加速?
  • C++ 优先算法 —— 三数之和(双指针)
  • YOLOv7-0.1部分代码阅读笔记-yolo.py
  • 【缓存与加速技术实践】Web缓存代理与CDN内容分发网络
  • MySQL的约束和三大范式
  • Unity网络通信(part7.分包和黏包)
  • 练习题 - DRF 3.x Overviewses 框架概述