freeCodeCamp/curriculum/challenges/portuguese/08-coding-interview-prep/rosetta-code/gray-code.portuguese.md

3.5 KiB

title id challengeType videoUrl localeTitle
Gray code 5a23c84252665b21eecc7e80 5 Código cinza

Description

O código cinza é uma forma de codificação binária em que as transições entre números consecutivos diferem em apenas um bit. Essa é uma codificação útil para reduzir os riscos de dados de hardware com valores que mudam rapidamente e / ou se conectam a hardware mais lento como entradas. Também é útil para gerar entradas para os mapas de Karnaugh , da esquerda para a direita ou de cima para baixo. Crie uma função para codificar um número e decodificar um número do código Gray. A função deve ter 2 parâmetros. O primeiro seria um booleano. A função deve codificar para true e decodificar para false. O segundo parâmetro seria o número a ser codificado / decodificado. Exibe as representações binárias normais, as representações do código Gray e os valores decodificados do código Gray para todos os números binários de 5 bits (0 a 31 inclusive, não sendo necessário 0). Existem muitos códigos Gray possíveis. O seguinte codifica o que é chamado de "código cinza refletido por binário".
Codificação (MSB é bit 0, b é binário, g é o código Gray):
if b[i-1] = 1
g[i] = not b[i]
else
g[i] = b[i]
Ou:
g = b xor (b logically right shifted 1 time)
Decodificação (MSB é bit 0, b é binário, g é o código Gray):
b[0] = g[0]
for other bits:
b[i] = g[i] xor b[i-1]

Instructions

Tests

tests:
  - text: <code>gray</code> deve ser uma função.
    testString: 'assert(typeof gray=="function","<code>gray</code> should be a function.");'
  - text: '<code>gray(true,177)</code> deve retornar um número.'
    testString: 'assert(typeof gray(true,177)=="number","<code>gray(true,177)</code> should return a number.");'
  - text: '<code>gray(true,177)</code> deve retornar <code>233</code> .'
    testString: 'assert.equal(gray(true,177),233,"<code>gray(true,177)</code> should return <code>233</code>.");'
  - text: '<code>gray(true,425)</code> deve retornar <code>381</code> .'
    testString: 'assert.equal(gray(true,425),381,"<code>gray(true,425)</code> should return <code>381</code>.");'
  - text: '<code>gray(true,870)</code> deve retornar <code>725</code> .'
    testString: 'assert.equal(gray(true,870),725,"<code>gray(true,870)</code> should return <code>725</code>.");'
  - text: '<code>gray(false,233)</code> deve retornar <code>177</code> .'
    testString: 'assert.equal(gray(false,233),177,"<code>gray(false,233)</code> should return <code>177</code>.");'
  - text: '<code>gray(false,381)</code> deve retornar <code>425</code> .'
    testString: 'assert.equal(gray(false,381),425,"<code>gray(false,381)</code> should return <code>425</code>.");'
  - text: '<code>gray(false,725)</code> deve retornar <code>870</code> .'
    testString: 'assert.equal(gray(false,725),870,"<code>gray(false,725)</code> should return <code>870</code>.");'

Challenge Seed

function gray(enc, number) {
 // Good luck!
}

Solution

// solution required