Gnome Sort一次只能处理一种元素,并将其移到实际位置。让我们看一个实现Gnome Sort的例子-
示例import java.util.Arrays;
public class Demo{
static void gnome_sort(int my_arr[], int n){
int index = 0;
while (index
if (index == 0)
index++;
if (my_arr[index] >= my_arr[index - 1])
index++;
else{
int temp = 0;
temp = my_arr[index];
my_arr[index] = my_arr[index - 1];
my_arr[index - 1] = temp;
index--;
}
}
return;
}
public static void main(String[] args){
int my_arr[] = { 34, 67, 89, 11, 0 , -21 };
gnome_sort(my_arr, my_arr.length);
System.out.println("The array after perfroming gnome sort on it is ");
System.out.println(Arrays.toString(my_arr));
}
}
输出结果The array after perfroming gnome sort on it is
[-21, 0, 11, 34, 67, 89]
名为Demo的类包含名为gnome_sort的静态函数。在此,将变量“索引”分配给0。如果该索引值小于数组的长度,则检查索引值是否为0。如果为0,则将其递增1。否则,如果值为0。一个特定的索引大于数组'index-1'的值,一个名为'temp'的变量被赋值为0,并且元素被交换。“索引”值递减。
在main函数中,使用某些值定义一个数组,并在该数组和数组的长度上调用'gnome_sort'函数。输出被打印在控制台上。