首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JML中的Java排序方法

JML中的Java排序方法
EN

Stack Overflow用户
提问于 2017-12-27 22:49:00
回答 1查看 471关注 0票数 0

我需要一个用于JML的排序方法,我尝试过插入排序,但我不知道我需要什么要求和确保或维护。请帮帮忙。我需要//@requires、//@requires和//@maintaining。

代码语言:javascript
复制
public class InsertionSort

{

void sort(int arr[])
{
    int n = arr.length;
    for (int i=1; i<n; ++i)
    {
        int key = arr[i];
        int j = i-1;
        while (j>=0 && arr[j] > key)
        {
            arr[j+1] = arr[j];
            j = j-1;
        }
        arr[j+1] = key;
    }
}
}
EN

回答 1

Stack Overflow用户

发布于 2018-01-20 12:56:37

下面的代码确保了升序并保留了重复。

代码语言:javascript
复制
//@ assignable arr[*];
//@ requires arr != null;
//@ ensures (\forall int i; 0 <= i && i <= arr.length-1; arr[i] <= arr[i+1]) &&
//@         (\forall int i; 0 <= i && i <= arr.length;
//@            (\num_of int j; 0 <= j && j <= arr.length;
//@               arr[i] == \old(arr[j])) ==
//@            (\num_of int j; 0 <= j && j <= arr.length;
//@               arr[i] == arr[j])
//@         );
//@            
void sort(int arr[])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47994171

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档