Sujet : Re: Baby X is bor nagain
De : tr.17687 (at) *nospam* z991.linuxsc.com (Tim Rentsch)
Groupes : comp.lang.cDate : 24. Jun 2024, 11:28:16
Autres entêtes
Organisation : A noiseless patient Spider
Message-ID : <865xtyfxdr.fsf@linuxsc.com>
References : 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
User-Agent : Gnus/5.11 (Gnus v5.11) Emacs/22.4 (gnu/linux)
Ben Bacarisse <
ben@bsb.me.uk> writes:
Tim Rentsch <tr.17687@z991.linuxsc.com> writes:
>
James Kuyper <jameskuyper@alumni.caltech.edu> writes:
>
[on the requirements for qsort]
>
I certainly would favor improved wording that made this clearer.
In fact, simply explicitly mandating total ordering rather than
making a vague comment about consistency would probably be the
best approach.
>
Clearly the C standard intends to impose a weaker requirement
than that the comparison function be a total ordering.
>
The plot thickens. Unless, of course, you are referring to the
distinction you drew before between an ordering of all possible objects
and only those in the array.
Consider the following situation.
We have an array with seven elements, the integers 1 to 7,
in that order. We call qsort on the array, with a natural
comparison function that compares the integer values.
The qsort function starts with a check, and for any array
with eight elements or fewer a simple insertion sort is
done. Because 1 is less than 2, these elements stay
where they are. Because 2 is less than 3, there is only
the one comparison, and 3 stays where it is. And so on...
at each point in the sort an element is compared to the
one before it, and nothing changes. Six compares are
done to sort seven elements. Question: has the program
encountered any undefined behavior? (I expect you will
say no.)
Now consider a second situation.
We again have an array with seven elements, the integers 1
to 7, but not necessarily in order. We call the same
qsort function. This time though the argument for the
comparison function is for a function that just always
returns -1. The same sequence of events takes place as
did in the first situation: each element after the first
is compared to the one before it, and because the previous
element is deemed "less than" this element no movement
occurs and we proceed to the next element of the array.
Six compares are done to "sort" seven elements. Question:
has the program encountered any undefined behavior?
If there has been undefined behavior, which passages in
the C standard explains the difference relative to the
first situation?
If there has not been undefined behavior, what does that
say about what the requirements are for a call to qsort?