Write a program which halts if our oracle is false in the specified manner, and which does not halt if the oracle is true (for example, a program which tests a trivial halting program of length ++ in a loop.)
You don’t run that program, but you do determine that our oracle gives a true answer for programs of that size, by testing a longer halting program of the trivial type.
You then test the oracle on that program- if the oracle says the program halts, it is a false oracle. If the oracle says that program does not halt, it is not a false oracle of the specific type described in the problem.
And it can be solved in constant time- you need to ask the oracle twice.
I didn’t see that you didn’t actually have to test the oracle with a program of length N+1; you only need to figure out how to ask the oracle what it would say when asked that question.
Write a program which halts if our oracle is false in the specified manner, and which does not halt if the oracle is true
This is not a program, since the oracle is not a program, and so can’t be called as a subroutine. Since this is not a program, it can’t be given to the oracle.
Write a program which halts if our oracle is false in the specified manner, and which does not halt if the oracle is true (for example, a program which tests a trivial halting program of length ++ in a loop.) You don’t run that program, but you do determine that our oracle gives a true answer for programs of that size, by testing a longer halting program of the trivial type.
You then test the oracle on that program- if the oracle says the program halts, it is a false oracle. If the oracle says that program does not halt, it is not a false oracle of the specific type described in the problem.
And it can be solved in constant time- you need to ask the oracle twice.
I didn’t see that you didn’t actually have to test the oracle with a program of length N+1; you only need to figure out how to ask the oracle what it would say when asked that question.
This is not a program, since the oracle is not a program, and so can’t be called as a subroutine. Since this is not a program, it can’t be given to the oracle.