一、问题

  • 问题1

    场景:如果你未来的丈母娘要求你,第1天给她1分钱,第2天给2分钱,第3天给4分钱,以此类推,每天给前一天的2倍,给1个月(按30天)算就行。
    问:第30天给多少钱,总共给多少钱?

  • 问题2

    场景:如果有两份工作。
       第1份:第1天给你1分钱,第2天给你2分钱,第3天给你4分钱,以此类推,每天给前一天的2倍,给1个月(按30天)。
       第2份:一个月给你10万工资。
    问:哪份工资高?给你选择的话,你要第1份还是第2份?

二、相关热搜关键词

  • 1天1分钱翻倍累计到三十天后多少钱
  • 1天1分钱第二天乘2
  • 1天1分钱每天翻2倍30天一共多少钱
  • 1天1分钱2天2分钱3天4分钱
  • 1天1分钱2天2分钱,以2倍的倍数,一个月多少钱?
  • 0.01每天翻倍30天是多少
  • 0.01每天翻倍月底多少钱
  • 0.01每天翻一倍

三、解题方法

  问题1和问题2,其实计算是一样的,在这里博主为大家介绍三种不同的解题方法,分别为:通过while循环方式、power函数结合等比数列通项和求和公式、CTE公用表达式递归方式。大家可以参考学习一下博主写的脚本。

  1. 使用while循环方式
    1.1 直接看脚本和相关注释:

    /*
    作者:zhang502219048
    脚本来源:https://www.cnblogs.com/zhang502219048/p/11273639.html
    功能:通过while循环实现计算1分钱翻倍1个月的问题
    */
    --定义变量
    declare @a decimal(18,2) = 0.01, --@a为每天多少钱,初始为第1天0.01元
    @total decimal(18,2) = 0, --@total为截至当天总共多少钱
    @q int = 2, --@q为每天翻多少倍
    @n int = 2, --@n为第几天,而且是从第2天开始,因为是第2天才开始翻倍
    @nMax int = 30 --@nMax为最后翻倍的那天 --while循环,计算到第30天,当天多少钱和截至当天总共多少钱
    while @n <= @nMax --从第2天开始进行循环,直到第30天
    begin
    select @a = @a * @q --计算当天多少钱
    select @total = @total + @a --计算截至当天总共多少钱
    select @n = @n + 1 --循环变量@n加1天
    end --输出信息
    print '第30天多少钱:'
    print @a
    print '第1到30天总共多少钱:'
    print @total
    go

    1.2 脚本运行结果:

  2. 使用power函数和等比数列通项和求和公式
    2.1 先来看看等比数列通项公式和求和公式是怎样的,学习一下:

    2.2 直接看脚本和相关注释:

    /*
    作者:zhang502219048
    脚本来源:https://www.cnblogs.com/zhang502219048/p/11273639.html
    功能:通过power函数和等比数列通项和求和公式实现计算1分钱翻倍1个月的问题
    */
    --定义变量
    declare @a1 decimal(18,2) = 0.01, --@a1为第1天0.01元
    @a30 decimal(18,2), --@a30为第30天多少钱
    @total decimal(18,2), --@total为截至当天总共多少钱
    @q int = 2, --@q为每天翻多少倍
    @n int = 30 --@n为总共几天 --使用power函数结合等比数列通项公式,计算第30天多少钱
    select @a30 = @a1 * power(@q, @n - 1) --power(@q, @n - 1):使用power函数计算@q的@n - 1次方
    --使用等比数列求和公式,计算截至第30天总共多少钱
    select @total = (@a1 - @a30 * @q)/(1 - @q) --输出信息
    print '第30天多少钱:'
    print @a30
    print '第1到30天总共多少钱:'
    print @total
    go

    2.3 脚本运行结果:

  3. 使用CTE公用表达式递归方式
    3.1 直接看脚本和相关注释:

    /*
    作者:zhang502219048
    脚本来源:https://www.cnblogs.com/zhang502219048/p/11273639.html
    功能:通过CTE递归方式实现计算1分钱翻倍1个月的问题
    字段说明:DayX为第几天,MoneyX为当天多少钱,MoneyTotal为截至当天总共多少钱
    */ with cte_table(DayX, MoneyX, MoneyTotal) as
    (
    select 1
    , cast(0.01 as decimal(18,2)) --第1天当天0.01元
    , cast(0.01 as decimal(18,2)) --截至第1天当天总共0.01元
    union all
    select DayX + 1 --DayX加1天
    , cast(MoneyX * 2 as decimal(18,2)) --第DayX + 1天当天多少钱
    , cast(MoneyTotal + MoneyX * 2 as decimal(18,2)) --截至第DayX + 1天当天总共多少钱
    from cte_table
    where DayX < 30 --计算到第30天截止,结束递归
    )
    select * from cte_table --查看明细数据(DayX:第几天;MoneyX:当天多少钱;MoneyTotal:截至当天总共多少钱)
    go

    3.2 脚本运行结果:

四、问题结论

  • 第30天给5,368,709.12元(五百多万)!
  • 截至第30天总共给10,737,418.23元(一千多万)!

五、问题扩展

六、作者声明

sql server编写脚本求解第1天1分钱之后每天两倍持续一个月的等比数列问题的更多相关文章

  1. Python编程求解第1天1分钱之后每天两倍持续一个月的等比数列问题

    一.问题 问题1 场景:如果你未来的丈母娘要求你,第1天给她1分钱,第2天给2分钱,第3天给4分钱,以此类推,每天给前一天的2倍,给1个月(按30天)算就行.问:第30天给多少钱,总共给多少钱? 问题 ...

  2. Sql Server中查询当天,最近三天,本周,本月,最近一个月,本季度的数据的sql语句

    --当天: --最近三天: --本周: select * from T_news WHERE (DATEPART(wk, addtime) = DATEPART(wk, GETDATE())) AND ...

  3. sql server编写简洁四则运算表达式脚本实现计算批次功能(C#等其它编程语言也能直接用此通用表达式)

    问题: 在数据库编程开发中,有时会遇到数据量比较大的情况,如果直接大批量进行添加数据.修改数据.删除数据,就会是比较大的事务,事务日志也比较大,耗时久的话会对正常操作造成一定的阻塞.虽不至于达到删库跑 ...

  4. sql server编写通用脚本自动统计各表数据量心得

    工作过程中,如果一个数据库的表比较多,手工编写统计脚本就会比较繁琐,于是摸索出自动生成各表统计数据量脚本的通用方法,直接上代码: /* 脚本来源:https://www.cnblogs.com/zha ...

  5. 一行导出所有任意微软SQL server数据脚本-基于Python的微软官方mssql-scripter工具使用全讲解

    文章标题: 一行导出所有任意微软SQL serer数据脚本-基于Python的微软官方mssql-scripter工具使用全讲解 关键字 : mssql-scripter,SQL Server 文章分 ...

  6. ola.hallengren的SQL Server维护脚本

    ola.hallengren的SQL Server维护脚本 下载地址 http://files.cnblogs.com/files/lyhabc/ola.hallengrenMaintenanceSo ...

  7. 非常全面的SQL Server巡检脚本来自sqlskills团队的Glenn Berry 大牛

    非常全面的SQL Server巡检脚本来自sqlskills团队的Glenn Berry 大牛 Glenn Berry 大牛会对这个脚本持续更新 -- SQL Server 2012 Diagnost ...

  8. SQL Server中的CLR编程——用.NET为SQL Server编写存储过程和函数

    原文:SQL Server中的CLR编程--用.NET为SQL Server编写存储过程和函数 很早就知道可以用.NET为SQL Server2005及以上版本编写存储过程.触发器和存储过程的,不过之 ...

  9. 非常全面的SQL Server巡检脚本来自sqlskills团队的Glenn Berry

    非常全面的SQL Server巡检脚本来自sqlskills团队的Glenn Berry Glenn Berry 曾承诺对这个脚本持续更新 -- SQL Server 2012 Diagnostic ...

随机推荐

  1. JavaScript基础5

    字符串操作方法和属性 length   获取字符串的长度 str.chartAt(指定字符的索引)  获取指定位置的字符 返回string类型的值 str.concat(字符串)   链接多个字符串  ...

  2. Python之Flask项目开发【入门必学】

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:藤藤菜丶 Flask 安装Flask模块 创建一个Flask项目 运行 ...

  3. 基于CC1606 FPGA评估板移植iCamera程序小结

    iCamera作为柴草电子经典的摄像头开发工具,其强大的摄像头调试功能,深受广大网友喜爱,支持市面上各种摄像头. 目前现有的应用板卡支持:CC1601(CP601A). CC1602(CP601B) ...

  4. 【Java Web开发学习】Spring4整合thymeleaf视图解析

    [Java Web开发学习]Spring4整合thymeleaf视图解析 目录 1.简单介绍2.简单例子 转载:https://www.cnblogs.com/yangchongxing/p/9111 ...

  5. 《Java知识应用》Java压缩文件和解压缩

    今天通过Java实现一下:文件的压缩和解压缩. 1. 压缩 准备文件: 准备代码:(压缩) import java.io.BufferedInputStream; import java.io.Buf ...

  6. 《Java基础知识》一维,二维数组的申明和使用

    为什么要使用数组: 因为不使用数组计算多个变量的时候太繁琐,不利于数据的处理. --------   数组也是一个变量,是存储一组相同类型的变量 声明一个变量就是在内存中划出一块合适的空间 声明一个数 ...

  7. springcloud-eureka高可用集群搭建

    一 前言 eureka作为注册中心,其充当着服务注册与发现功能,加载负载均衡:若在项目运行中eureka挂了,那么整个服务整体都会暂停,所以为服务运行的安全性,有必要搭建eureka集群:当其中一个e ...

  8. C语言笔记 08_函数指针&回调函数&字符串&结构体&位域

    函数指针 函数指针是指向函数的指针变量. 通常我们说的指针变量是指向一个整型.字符型或数组等变量,而函数指针是指向函数. 函数指针可以像一般函数一样,用于调用函数.传递参数. 函数指针变量的声明: / ...

  9. Microsemi Libero使用技巧——使用FlashPro生成stp程序文件

    前言 在工程代码编译完成之后,如果需要给某个芯片下载程序时,或者是工厂量产烧录程序时,我们不需要把整个工程文件给别人,而只需要把生成的下载文件给别人,然后使用FlashPro就可以单独下载程序文件了. ...

  10. 高精度模板 val.1

    目录 高精构造 结构体 char数组转高精: 高精加高精 高精乘单精 高精除单精 同样搬以前初三写的... 其实还有个val.2,搬到文章里去了 @ 在做一道斯特林数的时候被卡高精...于是滚来写一些 ...