首页 > 文章列表 > 在C++中,将以下内容翻译为中文:寻找长度和宽度之间差异最小的矩形

在C++中,将以下内容翻译为中文:寻找长度和宽度之间差异最小的矩形

长度 编程关键词: 寻找 宽度
162 2023-09-10

给定一个矩形区域作为输入。目标是找到矩形的边,使长度和宽度之间的差异最小。

矩形的面积 = 长度 * 宽度。

示例

< p>输入− 面积 = 100

输出− 差异最小的矩形边:

长度 = 10,宽度 = 10

解释− 面积 = 100 的边。

2 - 50、4 - 25、5 - 20、10 - 10。差异最小的边是 10-10,差值 = 0。众所周知,正方形是所有边长相等的矩形。

输入− 面积 = 254

输出− 具有最小差异的矩形边:

长度 = 127,宽度 = 2

解释 - 仅可能的边制作面积为 254 的矩形的最小差值为 127 和 2。

下面程序中使用的方法如下

在此我们将求面积的平方根值并进行遍历从那里到1,以便找到差异最小的值,并且area=输入区域。

  • 以整数变量Area作为输入。

  • 函数fragmentSides(int area1)接受area1并打印矩形的边长,长度和宽度之间的差异尽可能小。

  • 取整数长度、宽度、tmp1。

  • 设置 tmp1=ceil(sqrt(area1))

  • 使用 for 循环遍历 ( int i = tmp1;我 > 0; i--)。

  • 如果 (area1 % i == 0) 则设置长度=area/i 和宽度=i。

  • 使用break语句停止迭代。

  • 打印边长和宽度。

示例

#include <bits/stdc++.h>
using namespace std;
void rectangleSides(int area1){
   int length, breadth;
   int tmp1 = ceil(sqrt(area1));
   for (int i = tmp1; i > 0; i--) {
      if (area1 % i == 0) {

         length = ceil(area1 / i);
         breadth = i;
         break;
      }
   }
   cout<<"Sides of Rectangle with minimum difference :"<<endl;
   cout << "Length = " << length << ", Breadth = "   << breadth << endl;
}
int main(){
   int Area = 140;
   rectangleSides(Area);
   return 0;
}

输出

如果我们运行上面的代码,它将生成以下输出

Sides of Rectangle with minimum difference :
Length = 14, Breadth = 10