我正在尝试将Selection类型从Java转换为Scala,我不确定如何将此循环转换为Scala:
for (int j = i + 1; j < N; j++)
这是一个更大的Java代码示例及其Scala等价物:
Java:
sort(Comparable[] a)
{
int N = a.length;
for (int i = 0; i < N; i++)
{
int min = i
for (int j = i + 1; j < N; j++)
}
斯卡拉:
def sort(a : Array[Ordered[Any]]) = {
var N = a.length
for (i <- 0 until N) {
var min = i
for(j <- until j < N){
}
}
}
如何将内部循环转换为Scala?
for (int j = i + 1; j < N; j++)
我不知道在迭代时怎么做作业......
答案 0 :(得分:6)
你走了:
def sort(a : Array[Ordered[Any]]) = {
val N = a.length
for (i <- 0 until N) {
var min = i
for(j <- i + 1 until N){
}
}
}
此外,在Scala中,您可以定义内部的值以进行理解,并将多个块合并为一个:
def sort(a : Array[Ordered[Any]]) = {
val n = a.length
for(i <- 0 until n; min = i; j <- i + 1 until n) { // min here is val, not var
// do something with i, j and min
}
}
有时,这可能会导致更清晰的代码
答案 1 :(得分:3)
不幸的是,Scala的循环标准非常慢(特别是对于旧版本)。
另一种选择是经典的while循环,即使它不是那么清楚:
def sort(a : Array[Ordered[Any]]) = {
val N = a.length
var i = 0;
while (i < N) {
var min = i
var j = i + 1;
while (j < N) {
j += 1;
}
i += 1;
}
}
或尾递归函数:
def sort(a : Array[Ordered[Any]]) = {
val N = a.length
def l1(i: Int){
def l2(j: Int, min: Int){
if (j < N)
l2(j+1, min)
}
if (i < N) {
l2(i+1, i);
l1(i+1);
}
}
}
或尖顶的cfor:
def sort(a : Array[Ordered[Any]]) = {
val N = a.length
cfor(0)(_ < N, _ + 1) { i =>
var min = i
cfor(i+1)(_ < N, _ + 1) { j =>
}
}
}
答案 2 :(得分:0)
使用for循环(不完全是函数/惯用scala方式)进行迭代将非常类似于java代码。这将帮助您完成。
def sort(a: Array[Comparable]) {
val N = a.length
for (
i <- 0 until N;
min = i;
j <- (i + 1) until N
) {
// more code..
}
}
这是您的java代码供参考:
sort(Comparable[] a)
{
int N = a.length;
for (int i = 0; i < N; i++)
{
int min = i
for (int j = i + 1; j < N; j++)
}