Konwertuj wartości CMYK na RGB

9

Biorąc pod uwagę kody kolorów w CMYK, przekonwertuj je na wartość RGB.

Dane wejściowe:
ciąg 4 liczb całkowitych (od 0-100) oddzielonych spacją

86 86 0 43
28 14 0 6
0 41 73 4

Wynik:

#141592
#ABCDEF
#F49043 

Najkrótszy kod wygrywa!

WSKAZÓWKA: Do konwersji CMYK na RGB możesz użyć wzoru takiego jak:

Red   = 255 x (1 - Cyan/100)    x (1 - Black/100)   
Green = 255 x (1 - Magenta/100) x (1 - Black/100)   
Blue  = 255 x (1 - Yellow/100)  x (1 - Black/100)   

i użyj tych trzech zmiennych, aby uzyskać wartość w #RRGGBBformacie

Czy byłem
źródło
1
Możemy przyjąć CMYKwartości jak dziesiętne od 0celu 1, czy jest to wymagane, 0aby 100?
HyperNeutrino
1
Ponadto, czy mamy wprowadzić wiele kodów CMYK jednocześnie, czy tylko jeden i przekonwertować go?
HyperNeutrino
7
Czy możemy traktować dane wejściowe jako listę liczb, czy może to być ciąg znaków rozdzielany?
Business Cat
7
Podane dane wejściowe / wyjściowe nie są zgodne z formułą, a także w jaki sposób powinniśmy obsłużyć zaokrąglanie?
Rod
2
@Rod Nie jest jeszcze jasne, jak należy obsługiwać niedokładności zmiennoprzecinkowe.
Erik the Outgolfer

Odpowiedzi:

5

PHP , 90 bajtów

<?="#";for($c=explode(" ",$argn);$i<3;)printf("%02X",255*(1-$c[+$i++]/100)*(1-$c[3]/100));

Wypróbuj online!

Jörg Hülsermann
źródło
2

Python 3 , 100 98 bajtów

-2 bajty dzięki Rod.

lambda s:'#'+''.join('%02X'%int(.0255*(100-int(i))*(100-int(s.split()[3])))for i in s.split()[:3])

Wypróbuj online!

całkowicie ludzki
źródło
Gra w golfa z matematyki. o0 Dzięki!
całkowicieludzki
2

Galaretka , 24 bajty

ḲV÷ȷ2ạ1×Ṫ$×255ḞṃØHṙ1¤ṭ”#

Pełny program, który drukuje wynik.

Wypróbuj online!

Uwaga: można wstawić zaokrąglenie zamiast podłogi, wstawiając dwa bajty kodu +.między 255i .

W jaki sposób?

ḲV÷ȷ2ạ1×Ṫ$×255ḞṃØHṙ1¤ṭ”# - Main link: list of character, s
Ḳ                        - split at spaces (makes a list of lists of characters)
 V                       - evaluate as Jelly code (makes a list of the decimal numbers)
   ȷ2                    - literal 100
  ÷                      - divide (vectorises to yield [C/100, M/100, Y/100, K/100])
     ạ1                  - absolute difference with 1 -> [1-(C/100),...]
         $               - last two links as a monad:
        Ṫ                -   tail (this is 1-(K/100))
       ×                 -   multiply (vectorises across the other three)
          ×255           - multiply by 255 (vectorises)
              Ḟ          - floor to the nearest integer
                    ¤    - nilad followed by link(s) as a nilad:
                ØH       -   hex-digit yield = "0123456789ABCDEF"
                  ṙ1     -   rotate left by 1 -> "123456789ABCDEF0"
               ṃ         - base decompress (use those as the digits for base length (16))
                      ”# - literal character '#'
                     ṭ   - tack
                         - implicit print
Jonathan Allan
źródło
Innym sposobem na zaokrąglenie byłoby _.Ċzamiast +.Ḟ... ale to drugie może być szerzej stosowane.
Erik the Outgolfer
2

Siatkówka , 103 bajty

\d+
$*1;100$*
(1*);\1

1(?=.* (1*))|1
$1
1
51$*
(1{32000})*(1{2000})*1*.
;$#1;$#2
T`d`L`1\d
;B\B|;

^
#

Wypróbuj online! Uwaga: ten kod jest bardzo wolny, więc proszę nie hamować serwera Dennisa. Wyjaśnienie:

\d+
$*1;100$*
(1*);\1

Konwertuj każdą liczbę na unarną i odejmij od 100.

1(?=.* (1*))|1
$1

Pomnóż wszystkie liczby przez ostatni numer, który został usunięty.

1
51$*

Pomnóż przez 51, aby po podzieleniu przez 2000 otrzymać 100 * 100 * 51 / 2000 = 255pożądaną wartość.

(1{32000})*(1{2000})*1*.
;$#1;$#2

Podziel przez 32000, a podłogę podziel resztę przez 2000, generując w ten sposób parę wartości podstawy 16, choć niestety same wciąż są zapisane w podstawie 10.

T`d`L`1\d
;B\B|;

Konwertuj z bazy 10 na bazę 16.

^
#

Wstaw wiodące #.

Neil
źródło
2

Java 8, 166 bajtów

s->{int i=0,c[]=java.util.Arrays.stream(s.split(" ")).mapToInt(Byte::new).toArray();for(s="#";i<3;)s+=s.format("%02X",(int)(.0255*(100-c[i++])*(100-c[3])));return s;}

Wypróbuj online!

Justin Mariner
źródło
2

JavaScript (ES6), 106 bajtów

f=
(s,z=s.split` `,k=z.pop())=>'#'+z.map(x=>('0'+(.0255*(100-x)*(100-k)+.5|0).toString(16)).slice(-2)).join``
<input id=i value="28 14 0 6"/><button onclick="o.innerHTML=f(i.value)"/>Go</button>
<pre id=o></pre>

nderscore
źródło
2

C ++ (gcc) , 169 166 bajtów

#import<iostream>
#import<iomanip>
#define F(x)int(.0255*(100-x)*(100-k))
int main(){
int c,m,y,k;
std::cin>>c>>m>>y>>k;
std::cout<<"#"<<std::hex<<F(c)<<F(m)<<F(y);
}

Wypróbuj online!

Korzystanie ze zoptymalizowanej formuły. Dodano, +.5aby przekonwertować CMYK = 0 0 0 0popraw na RGB =0xffffff co nie jest konieczne.

Karl Napf
źródło
1

Python 3 , 114 110 108 106 104 bajtów

  • @ xnor zapisał 4 bajty: usunięto niepotrzebny kod
  • @rod zapisał 2 bajty: krótsza formuła
  • zapisane 2 + 2 bajty: range[3]as [0,1,2], niechciane []usunięte
n=input().split()
print('#'+''.join(hex(int(.0255*(100-int(n[i]))*(100-int(n[3]))))[2:]for i in[0,1,2]))

Wypróbuj online!

Officialaimm
źródło
1

Rubin , 92 + 1 dla flagi -p = 93 bajty

gsub(/(.+) (.+) (.+) (.+)/){'#%X%X%X'%[$1,$2,$3].map{|n|255*(1-n.to_i/1e2)*(1-$4.to_i/1e2)}}

Wypróbuj online!

Alexis Andersen
źródło
1

JavaScript, 104 bajty

s=>"#"+[0,1,2].map(n=>("0"+((255-2.55*s[n])*(1-s[3]/100)|0).toString(16)).slice(-2),s=s.split` `).join``

Przykładowy fragment kodu:

f=

s=>"#"+[0,1,2].map(n=>("0"+((255-2.55*s[n])*(1-s[3]/100)|0).toString(16)).slice(-2),s=s.split` `).join``

console.log(f("86 86 0 43"))
console.log(f("28 14 0 6"))
console.log(f("0 41 73 4"))

Herman L.
źródło
0

dc , 53 bajty

16o?35Pskrsprlpr[Fk100/1r-255*1lk100/-*0k1/nz0<b]dsbx

Wypróbuj online!

R. Kap
źródło
0

q / kdb +, 55 bajtów

Rozwiązanie:

"#",raze{(last($)0x0 vs)each"h"$.0255*x[3]*x 0 1 2}100-

Przykłady:

q)"#",raze{(last($)0x0 vs)each"h"$.0255*x[3]*x 0 1 2}100-86 86 0 43
"#141491"
q)"#",raze{(last($)0x0 vs)each"h"$.0255*x[3]*x 0 1 2}100-28 14 0 6
"#adcef0"
q)"#",raze{(last($)0x0 vs)each"h"$.0255*x[3]*x 0 1 2}100-0 41 73 4
"#f59042"

Wyjaśnienie:

Dość proste, ukradłem 0.0255lewę z innych rozwiązań (dzięki!). Ocena jest przeprowadzana od prawej do lewej.

"#",raze {(last string 0x0 vs) each "h"$ .0255 * a[3] * a 0 1 2}100- / ungolfed
         {                                                     }     / lambda function
                                                                100- / subtract from 100 (vector)
                                                        a 0 1 2      / index into a at 0, 1 and 2 (CMY)
                                                 a[3]                / index into at at 3 (K)
                                                      *              / multiply together
                                         .0255 *                     / multiply by 0.255
                                    "h"$                             / cast to shorts
          (                  ) each                                  / perform stuff in brackets on each list item
                       0x0 vs                                        / converts to hex, 1 -> 0x0001
                string                                               / cast to string, 0x0001 -> ["00", "01"]
           last                                                      / take the last one, "01"
    raze                                                             / join strings together
"#",                                                                 / prepend the hash

Uwagi:

Domyślnie zaokrągla liczby, kosztowałby 3 bajty (_)na podłogę przed rzutowaniem na skrót.

streetster
źródło
0

05AB1E , 18 bajtów

$#т/-¤s¨*255*hJ'#ì

Wypróbuj online!

-1 dzięki kalsowerus .

Ma niedokładności zmiennoprzecinkowe, więc wyniki mogą być nieparzyste, ale używana jest formuła w pytaniu.

Erik the Outgolfer
źródło
Możesz zapisać bajt: $jest taki sam jak
kalsowerus
@kalsowerus Cóż, nie do końca, ale zadziałałoby w tym przypadku ...
Erik Outgolfer
Och racja .. Nie jestem pewien, który sygnał wejściowy będzie, inputkiedy będzie wiele
kalsowerus
0

Haskell, 165 bajtów

q=(1-).(/100)
x!y=h$ceiling$q x*(q y)*255
f c m y k=concat["#",c!k,m!k,y!k]
h x|x<16=[s!!x]|0<1=(h((x-m)`quot`16))++[s!!m] where m=x`mod`16
s=['0'..'9']++['a'..'f']
Sergii Martynenko Jr
źródło
0

Fortran, 156 bajtów

PROGRAM C
REAL,DIMENSION(4,3)::d
READ(*,*)((d(i,j),i=1,4),j=1,3)
WRITE(*,'((A,3(Z2)))')(35,(INT(.0255*(100-d(i,j))*(100-d(4,j))),i=1,3),j=1,3)
END PROGRAM C
Zongor
źródło