将大小为l * b的面包切成更小的相同块,以使每块都是正方形,并具有最大可能的边长

问题描述

int restaurant(int l,int b) {

      int x,min,max,count=0,i;
 
   if(l<=b)           //here assigning min,max lengths of rectangle
  {
    min=l;
    max=b;
  } 
  else 
  {
     min=b;
     max=l;
  }

 int array[max];  

 for(x=1;(x<=min && x*x<=l*b);x++)  // here checking length of square not 
                                    // exceeding min length of rectangle & 
                                    // area of square not exceeding the 
                                    // area of rectangle
 {
    
     if((l*b)%(x*x)==0)              // here checks the x value for which 
                                     // there is no left over in bread,// storing that square length in an 
                                     // array
     {
         array[count]=x;
         count++;        
     }

 }

 x=array[0];                                    
 for(i=0;i<=count-1;i++)                  // getting maximum square length 
                                         //  'x' 
 {
   if(array[i]>=x)
   x=array[i];
 }

 return (l*b)/(x*x);                         // returning no. of square for 
                                             // the max. 'x'

}

您能解释一下为什么这种逻辑不起作用吗?

不。的平方=(l b)/(x x)

其中x是一个正方形的最大可能长度

该问题的链接如下 output

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)