challenge: implement the max function
Andrei Alexandrescu (See Website For Email)
SeeWebsiteForEmail at erdani.org
Mon Jan 22 13:29:58 PST 2007
S. wrote:
> Andrei Alexandrescu (See Website For Email) Wrote:
>
>> Here's a simple challenge: implement the max function. Requirements:
>>
>> a) generic
>> b) efficient
>> c) preserve lvalueness when possible such that one can write e.g.
>> max(arr[0], arr[1]) *= 0.9;
>> d) should accept two or more arguments
>> e) should return the "smartest" type, e.g. max of an unsigned int and
>> unsigned long should return unsigned long
>> f) short and easy to understand
>>
>> I don't think it's possible to implement the function to the spec in
>> current D, so designs are allowed to invent new features, as long as
>> they define them thoroughly.
>>
>> Looking forward to any takers!
>>
>>
>> Andrei
>
> Requirements C and E are mutually exclusive.
They are not. "When possible" says it all.
Andrei
More information about the Digitalmars-d
mailing list