Converti AWG in Pollici


9

AWG (American Wire Gauge) è un modo comune per specificare le dimensioni dei cavi. Il tuo compito in questa sfida è convertire da un dato calibro al diametro del filo in pollici.

Le dimensioni in pollici per i calibri da 4/0a 40sono mostrate nella tabella seguente:

Tabella da calibro a pollici

| AWG | Diameter (Inches) |
|-----|-------------------|
| 4/0 | 0.46              |
| 3/0 | 0.4096            |
| 2/0 | 0.3648            |
| 1/0 | 0.3249            |
| 1   | 0.2893            |
| 2   | 0.2576            |
| 3   | 0.2294            |
| 4   | 0.2043            |
| 5   | 0.1819            |
| 6   | 0.162             |
| 7   | 0.1443            |
| 8   | 0.1285            |
| 9   | 0.1144            |
| 10  | 0.1019            |
| 11  | 0.0907            |
| 12  | 0.0808            |
| 13  | 0.072             |
| 14  | 0.0641            |
| 15  | 0.0571            |
| 16  | 0.0508            |
| 17  | 0.0453            |
| 18  | 0.0403            |
| 19  | 0.0359            |
| 20  | 0.032             |
| 21  | 0.0285            |
| 22  | 0.0253            |
| 23  | 0.0226            |
| 24  | 0.0201            |
| 25  | 0.0179            |
| 26  | 0.0159            |
| 27  | 0.0142            |
| 28  | 0.0126            |
| 29  | 0.0113            |
| 30  | 0.01              |
| 31  | 0.00893           |
| 32  | 0.00795           |
| 33  | 0.00708           |
| 34  | 0.0063            |
| 35  | 0.00561           |
| 36  | 0.005             |
| 37  | 0.00445           |
| 38  | 0.00397           |
| 39  | 0.00353           |
| 40  | 0.00314           |

chiarimenti

  • Per calibri inferiori a 0, è possibile prendere l'input come uno 3/0o000
  • Devi solo supportare dal dato 4/0a40
  • La pagina di Wikipedia ha alcune formule utili che puoi provare a usare se non vuoi codificare tutto
  • Invia le tue risposte ad almeno 3 sig-fichi
  • Questo , quindi il codice più breve in byte vince!

24
È sorprendente ciò che gli americani possono fare per evitare di usare il sistema metrico :-P
Luis Mendo,

2
Questa non è complessità kolmogorov in quanto è una conversione in output e non un output costante
f 17nɛtɪk,

Possiamo prendere input come un array? 0000come [0, 0, 0, 0]e 40come[40]
miglia

Risposte:


3

JavaScript (ES7), 36 byte

s=>.46/92**(((+s||1-s.length)+3)/39)

Accetta input nel formato "0000".


3

J , 33 26 byte

0.46%92^39%~*@".{3+".,~1-#

Provalo online!

Prende l'input come stringa con calibri inferiori a zero come stringa di zero. Trova l'indice di quella stringa e divide 0,46 (il diametro di 0000) per la 39a radice di 92 (il rapporto tra i calibri) che molte volte.

Spiegazione

0.46%92^39%~*@".{3+".,~1-#  Input: string S
                         #  Length of S
                       1-   Subtract it from 1
                   ".,~     Eval S and append it, forms [1-len(S), eval(S)]
                 3+         Add 3 to each
            *@".            Sign of the eval
                {           Use that to index into the previous list
        39%~                Divide by 39
     92^                    Raise 92 to that power
0.46%                       Divide 0.46 by that and return

1

Utilità Bash + GNU, 47

bc -l<<<"e(l(92)*(36-(${1/\/0/*-1+1}))/39)/200"

Semplice valutazione dell'espressione aritmetica mediante bc. Input fornito come parametro della riga di comando.

Gli indicatori inferiori a 0 sono indicati come n/0. L'espansione del parametro bash${1/\/0/*-1+1} converte questi numeri in -ve e ne aggiunge uno che rende l'aritmetica corretta.

bc -lfornisce 20 cifre decimali per impostazione predefinita. bcL 'operatore di esponenziazione ^può gestire solo esponenti interi, quindi ln(y*e(x))viene utilizzato al suo posto.

Provalo online .


Forse menzionare che i valori di output mancano dello zero iniziale o aggiungerlo da soli? Come nota a margine, c'è anche la possibilità di risolverlo direttamente in uno script bc, anche se in più byte.
seshoumara,

1

Gelatina , 18 byte

VoLC$+3÷39µ92*.46÷

Provalo online!

Un collegamento monadico che prende una copia e restituisce un numero. I '0...0'casi producono un output supplementare, ma il valore di ritorno è corretto, come si può vedere ignorando le prime due righe qui .

Come?

VoLC$+3÷39µ92*.46÷ - Main link: guageString
V                  - evaluate as Jelly code (a string of zeros evaluates to 0)
    $              - last two links as a monad
  L                -     length
   C               -     complement (1-length)
 o                 - Or (integer value for > 0, 1-lenght for strings of zeros)
     +3            - add 3
       ÷39         - divide by 39
          µ        - monadic chain separation (call the result p)
              .46÷ - 0.46 divided by
           92*     - 92 raised to the power of p


0

05AB1E , 25 23 byte

8Ø50/92ID1‹ig(>}3+39/m/

Provalo online!

Spiegazione

8Ø                       # push the 8th prime (0-indexed) = 23
  50/                    # divide by 50 = 0.46
     92                  # push 92
       I                 # push input
        D1‹i   }         # if input < 1
            g(>          # calculate -len(input)+1
                3+       # add 3
                  39/    # divide by 39
                     m   # raise 92 to this power
                      /  # divide 0.46 by this

0

Excel, 53 49 byte

=92^((36-IF(ISNUMBER(A1),A1,49-CODE(A1)))/39)/200

Prende calibri inferiori a zero come stringa (1/0, 2/0 ecc.)


Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.