给定一个数值,计算最合适的行列数量的代码

本文详细解析了一种用于计算基于计数的行列布局算法。通过具体示例展示了算法的实现过程,包括行数和列数的计算逻辑。同时,对比了另一种算法方案,指出其存在的问题,帮助读者深入理解算法设计的考量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  其实代码很简单,需要的可以参考下。

int   countToRowColumn(const int count, int* pRows, int* pColumns)
{
    //这两个变量可以省略。
    int rows    = 0;
    int columns = 0;

    if (count <= 0 || pRows == NULL || pColumns == NULL)
    {
        return -1;
    }

    //先计算列数。
    columns = sqrt(count);
    if (columns*columns < count)
    {
        columns ++;
    }

    //再计算行数。
    rows   = count/columns;
    if (rows*columns < count)
    {
        rows ++;
    }

    *pRows    = rows;
    *pColumns = columns;

    return 0;
}

以5为例计算中间过程: 

columns=2

columns=3

rows = 1

rows = 2

返回。

 

有人如下代码如何,是不是更精简?

rows    = sqrt(count);
columns = rows;

if (rows*columns<count)
{
    columns++;
}

count=3;

rows=1;

columns=1;

columns=2;

返回,错误。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

柳鲲鹏

能给阁下一点帮助,非常荣幸

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值