Znajdź rangę słowa


23

Definicja

Ranga słowa jest definiowana jako pozycja słowa, gdy wszystkie możliwe kombinacje (lub układy) jego liter są ułożone alfabetycznie, jak w słowniku, bez względu na to, czy słowa są znaczące, czy nie.

Rozważmy te dwa słowa - „niebieski” i „widziany”. Na początek piszemy wszystkie możliwe układy liter tych słów w kolejności alfabetycznej:

"blue": "belu","beul","bleu","blue","buel","bule","eblu","ebul","elub","elbu","eubl",
        "eulb","lbeu","lbue","lebu","leub","lube","lueb","ubel","uble","uebl","uelb",
        "ulbe","uleb"
"seen": "eens","eesn","enes","ense","esen","esne","nees","nese","nsee","seen",
        "sene","snee"

Teraz spójrzmy od lewej strony i znajdź pozycję potrzebnych nam słów. Widzimy, że słowo „niebieski” znajduje się na 4 pozycji, a „widziany” na 10 pozycji. Zatem ranga słowa „niebieski” wynosi 4, a ranga „widziany” to 10. Jest to ogólny sposób obliczania rangi słowa. Upewnij się, że zaczynasz liczyć tylko od 1.

Zadanie

Twoim zadaniem jest napisanie kodu, który przyjmie dowolne słowo jako dane wejściowe i wyświetli jego pozycję. Ranga powinna być wynikiem. Uważaj na słowa zawierające powtarzające się litery.

Przykłady

"prime" -> 94

"super" -> 93

"bless" -> 4

"speech" -> 354

"earth" -> 28

"a" -> 1

"abcd" -> 1

"baa" -> 3    

Możesz założyć, że dane wejściowe są całkowicie pisane małymi literami, a dane wejściowe będą zawierać tylko znaki alfabetyczne . Również jeśli zostanie wprowadzona spacja lub niepoprawny ciąg, możesz zwrócić cokolwiek.

Punktacja

To jest , więc wygrywa najkrótszy kod!



14
„Pamiętaj, aby zacząć liczyć tylko od 1”. - To zależy od ciebie, ale pamiętaj, że dość powszechne jest dopuszczanie indeksowania opartego na 0 lub 1 dla takich wyzwań.
Jonathan Allan

1
Tak, ikr, ale jeśli zaczynasz od zera, to tak naprawdę nie wyświetlasz oryginalnej rangi, dlatego postanowiłem dodać ten wymóg.
Manish Kundu

Przydatny link . Otrzymasz AC, jeśli twój program uruchomi się na czas O(n log n)lub krócej. (przepraszam, brak Pythona) Moje przesłanie (C ++) zajmuje test 2.53s, aby rozwiązać test 14.
user202729 19.01.2018

Czy mogę zrobić krotkę lub listę z tym słowem, np ['h', 'e', 'l', 'l', 'o']. W przeciwieństwie do 'hello'?
0WJYxW9FMN

Odpowiedzi:





4

Pyth , 6 bajtów

hxS{.p

Zestaw testowy.

Wyjaśnienie

hxS {.p || Pełny program

    .p || Wszystkie permutacje danych wejściowych.
   {|| Deduplikacja.
  S || Sortować.
 x || Indeks danych wejściowych na tej liście.
h || Przyrost.

3

Galaretka , 5 bajtów

Œ!ṢQi

Wypróbuj online! lub zobacz zestaw testowy

Jak to działa

Œ!ṢQi - Main link. Argument: s (string)      e.g. 'baa'
Œ!    - All permutations                          ['baa', 'baa', 'aba', 'aab', 'aba', 'aab']
  Ṣ   - Sort                                      ['aab', 'aab', 'aba', 'aba', 'baa', 'baa']
   Q  - Deduplicate                               ['aab', 'aba', 'baa']
    i - 1-based index of s                        3

Nie działa w przypadku słów zawierających powtarzające się litery.
Manish Kundu

@ManishKundu i Xcoder, naprawiono
caird coinheringaahing

Niestety Œ¿nie działa
user202729,

Czy ṢŒ¿działa
Esolanging Fruit,

@EsolangingFruit Nie, to tylko wyniki1
Cairney Coheringaahing




2

Japt , 8 10 bajtów

0-indeksowane. Poxy, niepotrzebne indeksowanie 1, zwiększając moją liczbę bajtów o 25%!

á â n bU Ä

Sprawdź to


Wyjaśnienie

ápobiera wszystkie permutacje wejściu, âusuwa duplikaty, nsortuje je i bdostaje indeks pierwszego wystąpienia wejściu, U.


Zwróć uwagę na (nietypowe) wymaganie „Upewnij się, że zaczynasz liczyć od 1”. Skomentowałem pod OP, że normalne byłoby również zezwolenie na 0.
Jonathan Allan

1
Ach, cholera! stoopid 1-indeksowanie. Niedługo się zaktualizuje, ale zwiększy moją liczbę bajtów o 25%.
Shaggy

2

J , 28 23 bajtów

-5 bajtów dzięki FrownyFrog

1+/:~@~.@(A.~i.@!@#)i.]

Jak to działa?

                      ] - the argument
         (A.~      )    - permutations in the 
             i.@!@#     - range 0 to factorial of the arg. length
  /:~@~.@               - remove duplicates and sort
                    i.  - index of arg. in the sorted list
1+                      - add 1 (for 1-based indexing)

Wypróbuj online!


1
23:1+/:~@~.@(A.~i.@!@#)i.]
FrownyFrog,

@FrownyFrog - Dobre wykorzystanie i. za znalezienie indeksu! Dzięki!
Galen Iwanow

Link TIO jest wciąż starą wersją :)
Conor O'Brien

@Conor O'Brien - naprawiono
Galen Iwanow

Jak zwykle nie jestem zadowolony, dopóki nie otrzymasz rozwiązanie w K , która jest krótsza niż J jeden. To powiedziawszy, czy możesz użyć tej samej sztuczki tutaj? Wygenerować permutacje posortowanego ciągu wejściowego (usuwając w ten sposób potrzebę sortowania listy permutowanej)?
streetster

2

Tcl, 196 bajtów

proc p {a p} {if {$a eq {}} {lappend ::p $p} {while {[incr n]<=[llength $a]} {p [lreplace $a $n-1 $n-1] $p[lindex $a $n-1]}}}
p [split $argv ""] ""
puts [expr [lsearch [lsort -unique $p] $argv]+1]

Tcl nie ma wbudowanej metody obliczania następnej permutacji leksykograficznej, więc musimy to zrobić sami. Ale poczekaj ... jest to krótsze, aby to zrobić za pomocą prostej funkcji rekurencyjnej, która oblicza wszystkie możliwe permutacje w dowolnej kolejności.

Nie golfowany:

# Compute all possible permutations of the argument list
# Puts the result in ::all_permutations
proc generate_all_permutations {xs {prefixes ""}} {
  if {$xs eq {}} {
    lappend ::all_permutations $prefixes
  } else {
    while {[incr n] <= [llength $xs]} {
      generate_all_permutations [lreplace $xs $n-1 $n-1] $prefixes[lindex $xs $n-1]
    } 
  }
}

# Get our input as command-line argument, turn it into a list of letters
generate_all_permutations [split $argv ""]

# Sort, remove duplicates, find the original argument, and print its 1-based index
puts [expr [lsearch [lsort -unique $all_permutations] $argv]+1]


Więcej golenia tio.run/…
sergiol

Dziękuję Ci. Kiedy znów uzyskam dostęp do prawdziwego komputera, zaktualizuję.
Dúthomhas

2

K (oK) , 23 18 bajtów

Rozwiązanie:

1+*&x~/:?x@prm@<x:

Wypróbuj online!

Przykłady:

1+*&x~/:?x@prm@<x:"seen"
10
1+*&x~/:?x@prm@<x:"blue"
4

Wyjaśnienie:

Wygeneruj permutacje indeksów posortowanego ciągu wejściowego, użyj ich, aby zindeksować z powrotem ciąg wejściowy, weź różnice, zobacz, gdzie pasował oryginalny ciąg, i dodaj jeden.

1+*&x~/:?x@prm@<x: / the solution
                x: / save input string as x
               <   / return indices when sorting x ascending
           prm@    / apply (@) function prm
         x@        / index into x with these permutations
        ?          / distinct (remove duplicates)
    x~/:           / apply match (~) between x and each-right (/:)
   &               / return indexes where true (ie the match)
  *                / take the first one
1+                 / add 1 due to 1-indexing requirement

2

Java 8, 211 bajtów

import java.util.*;TreeSet q=new TreeSet();s->{p("",s);return-~q.headSet(s).size();}void p(String p,String s){int l=s.length(),i=0;if(l<1)q.add(p);for(;i<l;p(p+s.charAt(i),s.substring(0,i)+s.substring(++i,l)));}

Wyjaśnienie:

Wypróbuj online.

import java.util.*;        // Required import for TreeSet

TreeSet q=new TreeSet();   // Sorted Set on class-level

s->{                       // Method with String parameter and integer return-type
  p("",s);                 //  Save all unique permutations of the String in the sorted set
  return-~q.headSet(s).size();}
                           //  Return the 0-indexed index of the input in the set + 1

void p(String p,String s){ // Separated method with 2 String parameters and no return-type
  int l=s.length(),        //  The length of the String `s`
      i=0;                 //  Index integer, starting at 0
  if(l<1)                  //  If String `s` is empty
    q.add(p);              //   Add `p` to the set
  for(;i<l;                //  Loop from 0 to `l` (exclusive)
    p(                     //   Do a recursive call with:
      p+s.charAt(i),       //    `p` + the character at the current index of `s` as new `p`
      s.substring(0,i)+s.substring(++i,l)));}
                           //    And `s` minus this character as new `s`

2

Python 3 , 183 182 bajtów

Pierwsza odpowiedź, która działa w czasie wielomianowym!

a=[*map(ord,input())]
f=lambda x:x and x*f(x-1)or 1
c=[0]*98
for C in a:c[C]+=1
l=len(a)
F=f(l)
for i in c:F//=f(i)
r=1
for x in a:F//=l;l-=1;r+=sum(c[:x])*F;F*=c[x];c[x]-=1
print(r)

Wypróbuj online!

Wymagaj, aby dane wejściowe były pisane wielkimi literami, ponieważ ... zapisuje bajt.

Pełny program pobiera dane wejściowe stdini wyjściowe stdout.


Nazwy zmiennych: (rodzaj nieoznakowanego kodu)

a : permu
f : factorial
c : count_num
C : char
l : n_num_left
F : factor
r : result

Niestety from math import factorial as fzajmuje dokładnie 1 bajt więcej.


(Niepowiązana uwaga: sprawdziłem Combinatorica`pakiet Mathematica, nic przydatnego, w tym RankPermutation)


Ten kod jest naprawdę fajny.
Manish Kundu

1

Łuska , 6 bajtów

S€(OuP

Wypróbuj online! Czuję, że powinien istnieć sposób na upuszczenie (.

Wyjaśnienie:

 €     -- return index of the input 
S (    -- in the list generated by applying the following functions to the input:
     P -- permutations
    u  -- remove duplicates
   O   -- sort

1

Czysty , 113 111 bajtów

import StdEnv,StdLib
?s=elemIndex s[[]:removeDup(foldr(\a b=sort[insertAt i a x\\x<-b,i<-[0..length x]])[[]]s)]

Wypróbuj online!

+3 bajty do obsługi indeksowania 1: /





1

JavaScript (ES6), 106 100 bajtów

w=>(P=(a,s)=>a[0]?a.map((_,i)=>P(b=[...a],s+b.splice(i,1))):P[s]=P[s]||++k)[P([...w].sort(),k=''),w]

Przypadki testowe

W jaki sposób?

P () to nasza rekurencyjna funkcja permutacji. Ale otaczający obiekt P służy również do przechowywania szeregów permutacji.

P = (a, s) =>               // given an array of letters a[] and a string s
  a[0] ?                    // if a[] is not empty:
    a.map((_, i) =>         //   for each entry at position i in a[]:
      P(                    //     do a recursive call to P() with:
        b = [...a],         //       a copy b[] of a[], with a[i] removed
        s + b.splice(i, 1)  //       the extracted letter appended to s
      )                     //     end of recursive call
    )                       //   end of map()
  :                         // else:
    P[s] = P[s] || ++k      //   if P[s] is not already defined, set it to ++k

Kod owijania brzmi teraz:

w =>                        // given the input word w
  P[                        // return the permutation rank for w
    P(                      //   initial call to P() with:
      [...w].sort(),        //     the lexicographically sorted letters of w
      k = ''                //     s = k = '' (k is then coerced to a number)
    ),                      //   end of call
    w                       //   actual index used to read P[]
  ]                         // end of access to P[]

1

C ++, 230 bajtów

#include<algorithm>
#include<iostream>
#include<string>
using namespace std;void R(string s){int n=1;auto p=s;sort(begin(p),end(p));do if(p==s)cout<<n;while(++n,next_permutation(begin(p),end(p)));}int main(int n,char**a){R(a[1]);}

Zgodnie z moim pytaniem kod zdecydowanie musi być wykonywalny w obecnej postaci. Klauzula tylko funkcji jest w zasadzie śmieciami. : - @

Dziękuję tym, którzy uprzejmie odpowiedzieli na pytanie, co można dla mnie wyciąć. W interesie poprawnego kodu uniknąłem popularnego GCC obejmującego <bits / stdc ++. H>, co zawsze uważałem za kiepskie oszustwo.

Oto, co pozostało z mojego oryginalnego posta:


Zawsze nie jestem pewien, kiedy używam C i C ++, co liczy się do całkowitej liczby bajtów. Zgodnie z programem, funkcją lub fragmentem kodu? odpowiedź jest wciąż niejasna (chyba, że ​​to nie jest fragment kodu). Wybieram więc najkrótszą z dwóch możliwości.

Tutaj jest on niepolecany z niezbędnymi nagłówkami itp .:

#include <algorithm>
#include <iostream>
#include <string>
using namespace std;

void R( string s )
{
  int n = 1;
  auto p = s;
  sort( begin(p), end(p) );
  do if (p == s) cout << n;
  while (++n, next_permutation( begin(p), end(p) ));
}

int main( int n, char** a )
{
  R( a[1] );
}

To gra w golfa do 230 bajtów, jednej trzeciej standardowej płyty wymaganej przez każdy program C ++. (Więc nie czuję się tak źle, nie licząc tego, ale ponieważ nigdy nie widziałem stanowczej skargi w żaden sposób, OP będzie musiał mi powiedzieć, który woli spełnić „napisz kod, aby wziąć dowolne słowo jako dane wejściowe i wyświetlać swoją pozycję. ”)

Nie jestem również pewien, czy to spełnia „pozycję należy wyliczyć”.


1
Uh ... AFAIK nasze zasady liczyć konieczne ( using namespace std, #include <algorithm> nagłówki używane do określenia funkcji w bajtach I ... Nie. main(){}Jest to ważny C ++ (g ++) Program na 8 bajtów.
user202729

Nie staram się być smark uparty, ale widzę zgłoszeń do C i C ++ (jak również inne języki) cały czas , że to tylko jedna funkcja. Chcę ostatecznej odpowiedzi. Z tego właśnie powodu zazwyczaj nie gram w golfa w językach C. (I cieszę się, że regolf.)
Dúthomhas

1
Nawet w Pythonie import mathjest często konieczne. Pozwól mi znaleźć odpowiednią meta ...
user202729

@ Dúthomhas Te rozwiązania nie wymagają dołączenia nagłówka. Podstawowa arytmetyka nie wymaga nagłówka, a niektóre funkcje mogą być niejawnie zadeklarowane i wypełnione przez połączenie stdlib (jak putsi printf). Aby kod był prawidłowy, kod musi się kompilować i działać bez zmian. Zobacz: codegolf.meta.stackexchange.com/a/10085/45941
Mego

@Mego Bez deklaracji mainfunkcji nie można uruchomić bez zmian .
user202729,




0

PowerShell , 275 bajtów

param($s)function n($a){if($a-eq1){return}0..($a-1)|%{n($a-1);if($a-eq2){$b.ToString()}$p=($j-$a);[char]$t=$b[$p];for($z=($p+1);$z-lt$j;$z++){$b[($z-1)]=$b[$z]}$b[($z-1)]=$t}}if($s.length-eq1){1;exit}$b=New-Object Text.StringBuilder $s;(n($j=$s.length)|sort -u).indexOf($s)+1

Wypróbuj online!

To jest cholerny bałagan.

PowerShell nie ma wbudowanych permutacji, więc ten kod korzysta z algorytmu z tego miejsca (intensywnie grał w golfa), który jest dostępny na licencji Microsoft Limited Public License ( załącznik B na tej stronie licencjonowania).

Program pobiera dane wejściowe $sjako ciąg znaków, a następnie rozpoczyna się rzeczywisty program $b=New-Object .... Budujemy nowy obiekt StringBuilder , który jest (zasadniczo) zmiennym ciągiem znaków. Pozwoli nam to łatwiej obsługiwać permutacje. Następnie wywołujemy funkcjęn (ustawiając $jprzy tym długość łańcucha wejściowego), sortz -uflagą nique na wyjściu, bierzemy, .indexOf()aby znaleźć łańcuch wejściowy i dodajemy, 1ponieważ PowerShell jest indeksowany na zero.

Ta funkcja jest główną częścią programu. Pobiera na wejściu liczbę i każda iteracja odlicza do osiągnięcia 1(tj. Pojedynczej litery). Reszta funkcji zasadniczo rekurencyjnie wywołuje funkcję, a także pobiera bieżącą literę i iteruje ją przez każdą pozycję.

Istnieje jeden dodatkowy element logiki if($s.length-eq1){1;exit}do uwzględnienia łańcuchów wejściowych długości 1ze względu na działanie funkcji permutacji.


0

Pyt , 5 bajtów

ĐᒆỤ≥Ʃ

Wyjaśnienie:

            Implicit input
Đ           Duplicate input
 ᒆ         Get list of all permutations of input
  Ụ         Get unique permutations
   ≥        Does each permutation come before or is equal to the input?
    Ʃ       Sum of result of previous step (converts booleans to ints)

Wypróbuj online!

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.