0

0

大于p的最小三角数

王林

王林

发布时间:2023-09-20 19:13:02

|

1274人浏览过

|

来源于tutorialspoint

转载

大于p的最小三角数

我们将讨论三角形数以及如何找到仅大于给定数字“num”的最小三角形数。我们先讨论什么是三角数,然后找出比“num”大的最小三角数

我们将看到针对同一问题的两种不同方法。在第一种方法中,我们将运行一个简单的循环来生成输出,而在第二种方法中,我们将首先生成一个用于计算所需数字的通用公式,然后直接应用该公式来获得最小的三角形数。 p>

问题陈述

我们必须找出仅大于“num”的最小三角形数。

我们有多个装有球的盒子。对于所有盒子来说,盒子包含的球的数量都是一个不同的三角形数字。这些盒子从 1 到 n 编号。我们必须找出从盒子中取出“num”个球后哪个盒子将包含最少数量的球。

让我们通过一个例子来理解这一点

Input number was: num = 5

我们必须找出取出 5 个球后哪个盒子里的球数最少

Output:3rd box will contain a minimum of balls after removing 4 balls.

此示例的解决方案 -

Boxes with number of balls: {1 3 6 10 ....}
Box 3 will contain only 1 ball after removing 4 balls from it.

什么是三角数?

三角形数是可以用等边三角形网格形式表示的数。一行中的点数始终等于行号,即第一行将包含 1 个点,第二行将包含 2 个点,依此类推。几个三角形数字是:1、3、6、10、15……。现在让我们推导出第 n 个三角形数的公式 -

我们知道,三角形数的第n行包含n个点,因此三角形数可以表示为每行中的点之和。我们还知道,第n个三角数有n行,因此第n个三角数可以由前n个自然数之和给出。

方法 1:(直接方法)

在这种方法中,我们将运行一个循环并计算给定数字和第 n 个三角数之间的差,当我们得到差值 >=0 时,我们将获得所需的盒子编号,因此我们将截断循环。

对于三角数,我们将继续将 n 与现有的第 (n-1) 个三角数相加,以计算下一个三角数的值。

算法

  • 第 1 步 - 将变量 triangular_number 初始化为 0。

  • 第 2 步 - 运行 for 循环并为每次迭代不断添加 n。

  • 第 3 步 - 继续计算三角形数与给定数字“num”之间的差。

    iWebShop开源商城系统
    iWebShop开源商城系统

    iWebShop是一款基于PHP语言及MYSQL数据库开发的B2B2C多用户开源免费的商城系统,系统支持自营和多商家入驻、集成微信商城、手机商城、移动端APP商城、三级分销、视频电商直播、微信小程序等于一体,它可以承载大数据量且性能优良,还可以跨平台,界面美观功能丰富是电商建站首选源码。iWebShop开源商城系统 v5.14 更新日志:新增商品编辑页面规格图片上传优化商品详情页面规格图片与主图切

    下载
  • 第 4 步 - 当我们得到差异 >=0 时,我们将打印 n 作为所需的框编号。

示例

这种方法在 C++ 中的实现如下 -

#include 
using namespace std;
int main(){
   int num = 1234;
   int triangular_number = 0;
   for (int n=1; triangular_number<=num; n++){
      triangular_number = triangular_number + n;
      if((triangular_number-num)>=0){
         cout<<"The smallest triangular number larger than "<

输出

The smallest triangular number larger than 1234 is 50

方法 2:基于公式的方法

在这种方法中,我们首先生成一个计算所需数字的通用公式,然后直接应用该公式来获得仅大于给定数字的最小三角形数。

第 n 个盒子编号的三角形数由下式给出 -

Triangular number = (n*(n+1))/2

获取最小的盒子编号“n”,使得三角形数>=num。

i.e. (n*(n+1))/2 >= num

这意味着我们必须解决 -

n2 + n – 2*num >= 0

使用这个方程,我们得到

n = ceil( (sqrt(8*num+1)-1)/2 )

示例

此方法的代码由以下给出 -

#include
using namespace std;
int boxnum(int num){
   return ceil( ( sqrt( 8*num + 1 ) -1 ) / 2 ) ;
}
int main(){
   int num = 1234 ;
   cout << "The smallest triangular number larger than "<

输出

The smallest triangular number larger than 1234 is 50

此方法的时间复杂度 - O(logn)

空间复杂度 - O(1),因为我们只使用恒定的额外空间。

在本文中,我们讨论了两种不同的方法来查找仅大于给定数字“num”的最小三角形数。第一种方法只是通过运行循环并为每次迭代添加 n 来计算三角数。我们同时计算了给定数和三角数之间的差。在第二种方法中,我们生成了一个数学公式来计算我们所需的输出。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

400

2023.08.14

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

37

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

37

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.5万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.1万人学习

Django 教程
Django 教程

共28课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号