V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
KamL
V2EX  ›  问与答

请教一下这种情况的话属于哪种算法可以解决呢?

  •  
  •   KamL · 2023 年 3 月 3 日 · 1042 次点击
    这是一个创建于 1044 天前的主题,其中的信息可能已经有所发展或是发生改变。
    业务中碰到难道这样的需求.....
    需要用户输入 6 个数据:
    起始层,列,排 [a, b, c]
    终止层,列,排。[x, y, z]
    根据输入的起始和终止数据创建(a~x)*(b~y)*(c-z)个数据,如:
    起始 1,1,1 终止 10,10,2 (需要创建 200 个对象,每个对象的层( 1~10 ),列( 1~10 ),排( 1~2 )有对应的坐标)

    如果不想用三层 for 循环的话可以,有没有哪道 leetcode 题目的算法是类似的可以解决这个问题?
    3 条回复    2023-03-04 13:11:47 +08:00
    LxExExl
        1
    LxExExl  
       2023 年 3 月 3 日 via iPhone
    需要创建 x*y*z 个结果,每个结果复杂度是 O(1), 这已经需要三个循环了。咋可能更快呢?

    还是楼主需要那种 one liner 语法糖呢?
    KamL
        2
    KamL  
    OP
       2023 年 3 月 3 日
    刚开始修炼算法,被 leetcode 的题目震撼,以为有那种可以更精妙的写法
    whileFalse
        3
    whileFalse  
       2023 年 3 月 4 日
    可以把三维数组展开成单维数组,但在业务场景上性能差不了太多,没意义还影响阅读。
    关于   ·   帮助文档   ·   自助推广系统   ·   博客   ·   API   ·   FAQ   ·   Solana   ·   988 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 23:11 · PVG 07:11 · LAX 15:11 · JFK 18:11
    ♥ Do have faith in what you're doing.