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

给c++小白的教程11:优化(1)

大家好!我们又见面了。

上次的第9期教程说10期讲这个,但因为太久没更忘了()

所以今天讲一下代码的优化。

上课了,c++老师出了一道题:

输入n(自然数),输出1~n的自然数之和。

赫炎第一个做出来:(这里为了方便只展示main函数里的内容)

int n;
cin>>n;
int sum=0;
for(int i=1;i<=n;i++)sum+=i;
cout<<sum;
return 0;

但冰霖表示不服:

int n;
cin>>n;
cout<<n*(n+1)/2;
return 0;

可以看到,两者相比,冰霖的代码少定义了一个变量,还少了一个循环,使代码运行的时间更短了。

那,冰霖的依据在哪里呢?

作为一个数学学霸,冰霖自有依据:

首先写出1~n:1,2,3,……,n-1,n

接着,将第一项与最后一项相加,第二项与倒数第二项相加……以此类推,就可得到:

(n+1)+(n-1+2)+(n-2+3)……

=(n+1)+(n+1)+(n+1)……

因为此刻两项合并成一项,所以项数要/2.

所以得(n+1)*n/2.

小声bb:这也是等差数列的求和公式——(首+尾)*项数/2

所以说,我们都要学习冰霖。但,这是要有一定数学底子的,如果小白们医师想不出来,建议还是乖乖循环。

接下来我们看向9期的练习题之一:一尺之锤

传送门

大意:给定一个n,每次/2,向下取整,问几次变成1

作者代码:

#include<bits/stdc++.h>
using namespace std;
int main() {int n;cin>>n;cout<<floor(log2(n))+1;return 0;
}

这里,floor是向下取整函数,log2是求n以2为底的自然对数(说人话:n是2的多少次方)

推导过程:

因为他这题是每次除以二,所以我们首先要求log2(n)

有可能会得小数,所以要向下取整。(向上取整或四舍五入都会让结果不准确)

而加一是因为作者试出来的

由题意得是从第二天开始切,第一天是不动的。所以要加1.

本期没有练习题,主要是让大家学习这个思想。

都给我好好学数学!!!


http://www.mrgr.cn/news/57094.html

相关文章:

  • 阿里云服务器ECS重装实例操作系统
  • c++ 左值和右值
  • vue中如何检测数组变化(vue基础,面试,源码级讲解)
  • 阿里巴巴商品详情API返回值中的促销与优惠信息
  • 第8篇:网络安全基础
  • Win安装Redis
  • Django自定义过滤器
  • ffmpeg环境
  • 拍摄照片(鸿蒙系统01)
  • D46【python 接口自动化学习】- python基础之类
  • stl(1)pair
  • JVM、字节码文件介绍
  • 四、多线程带来的的⻛险-线程安全
  • webpack4 - 动态导入文件 dynamic-import 报错的解决方法
  • 安装Python及pip使用方法详解
  • 重生之“我打数据结构,真的假的?”--1.单链表(无习题)
  • React写关键字高亮的三个方案
  • 第二期:第15节,beep 大海
  • latex表格单独编译成pdf表格
  • 华为配置 之 划分VLAN
  • 哪些WordPress的AI插件,更适合收集整理地球前100大行业的信息和关键词?谢谢。0.1
  • SAP B1 缺少税务科目 - 报错 debug
  • 秃姐学AI系列之:FCN + 代码实现
  • java和嵌入式现在哪个好?
  • js 防抖函数避免重复点击提交
  • 全域商户抽佣系统:智能分账新时代