Puoi usare la funzione rank() per questo:
select name, color1, color2, color3, prize
from (
select t.*, rank() over (order by decode(color1, 'Red', 1, 0)
+ decode(color2, 'Blue', 1, 0) + decode(color3, 'Green', 1, 0) desc) rnk
from t)
where rnk = 1
Questo restituisce la riga o le righe con la maggior parte delle corrispondenze.