【问题标题】:Unfold the loop three times [closed]展开循环三遍[关闭]
【发布时间】:2020-12-19 21:14:47
【问题描述】:

我得到了这个 Java 函数,我必须编写一段代码,该代码通过展开循环三次而得到。什么意思?

int f(int x, int y) {
   while (true) {
       int m = x % y;
       if(m == 0) return y;
       x = y;
       y = m;
   }
}

【问题讨论】:

  • 大概,“展开”与“展开”是一样的,所以参见例如Wikipedia 是什么意思。
  • @Andreas 我读过它,但仍然不知道如何在我的函数中申请

标签: java loops unfold


【解决方案1】:

意思是循环内的代码重复多次,然后重构代码进行优化。

如果我们重复一次,让我们看看效果如何。

int f(int x, int y) {
    while (true) {
        int m = x % y;
        if(m == 0) return y;
        x = y;
        y = m;
        
        m = x % y;
        if(m == 0) return y;
        x = y;
        y = m;
    }
}

通过轮换变量的使用,我们可以消除中间的两个简单赋值,从而优化代码。

int f(int x, int y) {
    while (true) {
        int m = x % y;
        if(m == 0) return y;
        
        x = y % m;
        if(x == 0) return m;
        y = x;
        x = m;
    }
}

现在再重复一次,并轮换第三个副本中的变量,总共 3 次“相同”代码,如分配中指定的那样。

我将把它留给你来完成,因为这是你完成的任务。如果操作正确,您会发现结果中没有简单赋值。

【讨论】:

    猜你喜欢
    • 2014-07-31
    • 2011-07-28
    • 2017-05-21
    • 2012-02-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-02-03
    • 2016-03-15
    相关资源
    最近更新 更多