{
    "id": "verina_basic_51",
    "signature": {
        "name": "BinarySearch",
        "parameters": [
            {
                "param_name": "a",
                "param_type": "Array Int"
            },
            {
                "param_name": "key",
                "param_type": "Int"
            }
        ],
        "return_type": "Nat"
    },
    "description_file": "./description.txt",
    "lean_file": "./task.lean",
    "specification": {
        "preconditions": "- The array must be sorted in non-decreasing order.",
        "postconditions": "- The returned index n satisfies n \u2264 a.size.\n- For every i < n, a[i]! < key.\n- If n = a.size, then for all i < a.size, a[i]! < key.\n- For every i with n \u2264 i < a.size, a[i]! \u2265 key."
    },
    "metadata": {
        "upstream": {
            "name": "clover",
            "link": "https://github.com/ChuyueSun/Clover",
            "task_id": "Clover_binary_search"
        }
    },
    "test_file": "./test.json",
    "reject_inputs_file": "./reject_inputs.json"
}