Skip to content

Commit 053537d

Browse files
committed
Pequenas correcoes nas docstrings (rust)
1 parent 45f1504 commit 053537d

File tree

4 files changed

+57
-57
lines changed

4 files changed

+57
-57
lines changed

src/rust/bogo_sort.rs

+12-12
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,12 @@
1-
/*
1+
/*
22
Contribuidores
33
- Dromedario de Chapéu
4-
5-
O Bogo Sort é um algoritmo feito apenas como uma piada, feito
6-
o pior e mais demorado algoritmo de ordenação. Tudo que ele faz
4+
5+
O Bogo Sort é um algoritmo feito apenas como uma piada, sendo
6+
o pior e mais demorado algoritmo de ordenação. Tudo o que ele faz
77
é pegar uma lista, randomizar os seus itens, e verificar se todos
8-
os itens estão ordenados. Logo se tor 100% aleatório, o que pode
9-
fazer com que demore mais de 1 milhão de tentativas ate ser ordenado,
8+
os itens estão ordenados. Logo, ele é 100% aleatório, o que pode
9+
fazer com que demore mais de 1 milhão de tentativas até ser ordenado,
1010
ou que simplesmente na primeira tentativa ele seja ordenado.
1111
1212
*/
@@ -24,25 +24,25 @@ fn verifica_ordem(lista: Vec<u8>) -> bool {
2424
return true;
2525
}
2626

27-
// Vec<u8> significa que o parâmetro "lista" é uma lista de
27+
// Vec<u8> significa que o parâmetro "lista" é uma lista de
2828
// inteiros sem sinal de 8 bits. E o retorno u64 se refere
2929
// ao total de ciclos necessários para realizar a ordenação
3030
fn bogo_sort(mut lista: Vec<u8>) -> (Vec<u8>, u64) {
3131
let mut rng = thread_rng();
32-
// Foi escolhido um limite tão grande justamente pelo bogo sort
33-
// poder ser tanto o algoritmo mais rápido quanto o mais lento,
32+
// Foi escolhido um limite tão grande justamente pelo bogo sort
33+
// poder ser tanto o algoritmo mais rápido quanto o mais lento,
3434
// então para não crashar o programa é bom um range grande
3535
let mut ciclos: u64 = 0;
3636
loop {
3737
ciclos +=1;
3838
lista.shuffle(&mut rng);
3939
if verifica_ordem(lista.clone()) {
4040
return (lista, ciclos);
41-
}
41+
}
4242
}
4343
}
4444

45-
// O valor de u8 para os itens da lista é apenas para
45+
// O valor de u8 para os itens da lista é apenas para
4646
// gerar números muito grandes e dificultar na visualização
4747
fn gera_lista(len: u8) -> Vec<u8> {
4848
let mut rng = thread_rng();
@@ -86,4 +86,4 @@ mod test {
8686
let (ordenada, _) = bogo_sort(desordenada);
8787
assert_eq!(ordenada, vec![1, 2, 3, 4, 5, 6]);
8888
}
89-
}
89+
}

src/rust/busca_binaria.rs

+27-27
Original file line numberDiff line numberDiff line change
@@ -1,46 +1,46 @@
1-
/*
1+
/*
22
Contribuidores
33
- Dromedario de Chapéu
4-
4+
55
O que é busca Binaria -
6-
"A busca binária é um eficiente algoritmo para encontrar um item em uma lista
7-
ordenada de itens. Ela funciona dividindo repetidamente pela metade a porção da
8-
lista que deve conter o item, até reduzir as localizações possíveis a apenas uma.
6+
"A busca binária é um eficiente algoritmo para encontrar um item em uma lista
7+
ordenada de itens. Ela funciona dividindo repetidamente pela metade a porção da
8+
lista que deve conter o item, até reduzir as localizações possíveis a apenas uma.
99
Nós usamos a busca binária em um jogo de adivinhação no tutorial introdutório."
1010
- Khan Academy : https://pt.khanacademy.org/computing/computer-science/algorithms/binary-search/a/binary-search
1111
*/
1212

1313
// O <T> em Rust indica que não se espera tipo especifico e sim qualquer tipo
1414
// no caso o T é usado para indicar o tipo dos valores da lista e o valor a ser
1515
// procurado.
16-
fn busca_binaria<T>(lista: &[T], valor: T) -> (bool, usize)
16+
fn busca_binaria<T>(lista: &[T], valor: T) -> (bool, usize)
1717
where
1818
// É preciso especificar que T implementa as Traits PartialEq e PartialOrd para
1919
// indicar que T pode ser comparado T e que possui uma ordem de maior e menor
20-
T: PartialEq,
20+
T: PartialEq,
2121
T: PartialOrd,
2222
{
2323
// Centro indica o centro a lista ou sublista
24-
let mut centro = lista.len() / 2;
25-
24+
let mut centro = lista.len() / 2;
25+
2626
// Limite_r representa o maior indice possível, referente ao extremo direito
27-
// da lista atual, serve para dividir a lista original sem precisar ficar
27+
// da lista atual, serve para dividir a lista original sem precisar ficar
2828
// clonando ou literalmente dividindo. Seria o [-1] da sublista
29-
let mut limite_r = lista.len() - 1;
30-
31-
// Limite_l representa o mesmo que Limite_r porem para o extremo esquerdo,
32-
// ou sejá, o [0] da sub lista.
29+
let mut limite_r = lista.len() - 1;
30+
31+
// Limite_l representa o mesmo que Limite_r porem para o extremo esquerdo,
32+
// ou seja, o [0] da sub lista.
3333
let mut limite_l = 0;
3434

3535
loop {
36-
// O valor esta sendo passado por referencia e depois acessado pelo seu
37-
// ponteiro pelo sistema de owenrship o Rust, isso pode feito com atribuição
36+
// O valor esta sendo passado por referencia e depois acessado pelo seu
37+
// ponteiro pelo sistema de ownership o Rust, isso pode feito com atribuição
3838
// simples como `valor_p = lista[centro]` em um Python por exemplo
39-
let valor_p = &lista[centro];
39+
let valor_p = &lista[centro];
4040

4141
// O primeiro bloco de if se responsabiliza em verificar se o valor que estamos
4242
// buscado foi encontrado, caso não ele verifica da ultima operação para esta
43-
// o centro não mudou de posição, ou sejá, não ha mais valores para verificar
43+
// o centro não mudou de posição, ou seja, não ha mais valores para verificar
4444
// e o item não existe
4545
if *valor_p == valor {
4646
return (true, centro)
@@ -52,19 +52,19 @@ where
5252
// e o atual valor_p, caso seja valor_p seja maior, significa que o valor procurado
5353
// esta mais para trás, e o centro é movido para o centro da sub lista anterior.
5454
// Porem caso valor seja maior que o valor_p, significa que precisamos mover o centro
55-
// para o centro da sub lista superiors
55+
// para o centro da sub lista superiors
5656
if *valor_p > valor {
57-
limite_r = centro;
57+
limite_r = centro;
5858
centro = centro / 2;
5959
} else if *valor_p < valor {
6060
limite_l = centro;
6161
// O If esta verificando se o espaço entre limite_r e limite_l é igual a 1
62-
// pois a operação de padrão usada daria o resultado de 0 nesse caso, pois
62+
// pois a operação de padrão usada daria o resultado de 0 nesse caso, pois
6363
// Rust arredonda os valores para baixo, logo 0.5 é jogado para 0
64-
// Poderia ser feito em uma linha utilizado conversão de tipos e arredondamento
64+
// Poderia ser feito em uma linha utilizado conversão de tipos e arredondamento
6565
// porem eu pessoalmente acredito que a performance ganha não vale compensa
66-
67-
centro = if (limite_r - limite_l) == 1 { centro + 1 }
66+
67+
centro = if (limite_r - limite_l) == 1 { centro + 1 }
6868
else { centro + (limite_r - limite_l) / 2 };
6969
// Forma em uma linha -
7070
// centro = centro + (((limite_r - limite_l) as f32 / 2.0).ceil() as usize);
@@ -82,13 +82,13 @@ fn main() {
8282
mod test {
8383
use super::*;
8484

85-
#[test]
85+
#[test]
8686
fn busca() {
87-
let lista = vec![-3, -2, -1, 0, 1, 2, 3];
87+
let lista = vec![-3, -2, -1, 0, 1, 2, 3];
8888
assert_eq!(busca_binaria(&lista, -7), (false, 0));
8989
assert_eq!(busca_binaria(&lista, -2), (true, 1));
9090
assert_eq!(busca_binaria(&lista, 0), (true, 3));
9191
assert_eq!(busca_binaria(&lista, 2), (true, 5));
9292
assert_eq!(busca_binaria(&lista, 7), (false, 0));
9393
}
94-
}
94+
}

src/rust/busca_sequencial.rs

+11-11
Original file line numberDiff line numberDiff line change
@@ -1,24 +1,24 @@
1-
/*
1+
/*
22
Contribuidores
33
- Dromedario de Chapéu
4-
5-
Busca Sequencial é o mais simples algoritmo de busca possessive, alem de
6-
ser um dos menos eficientes. Ele simplesmente itera por todos os itens
7-
de uma lista ate encontrar o valor desejado ou atingir o final da lista
4+
5+
Busca Sequencial é o mais simples algoritmo de busca possessive, alem de
6+
ser um dos menos eficientes. Ele simplesmente itera por todos os itens
7+
de uma lista até encontrar o valor desejado ou atingir o final da lista
88
retornando que o elemento não esta presente na lista.
99
10-
Esse algorítimo pode ser útil para listas pequenas de algumas poucas centenas
11-
de valores de tipo simples, porem mais que isso ele sera um grande gargalo
10+
Esse algoritmo pode ser útil para listas pequenas de algumas poucas centenas
11+
de valores de tipo simples, porem mais que isso ele sera um grande gargalo
1212
durante a execução do programa.
1313
14-
Uma possível vantagem deste algoritmo, é que ele independe da lista esta
15-
ordenada para funcionar. Pois ele não se importa com a ordem dos elementos.
14+
Uma possível vantagem deste algoritmo, é que ele independe da lista estar
15+
ordenada para funcionar, pois ele não se importa com a ordem dos elementos.
1616
*/
1717
fn busca_sequencial(lista: &[i32], valor: i32) -> (bool, usize) {
1818
for (i, c) in lista.iter().enumerate() {
1919
if *c == valor {
2020
return (true, i);
21-
}
21+
}
2222
}
2323
return (false, 0);
2424
}
@@ -39,4 +39,4 @@ mod test {
3939
assert_eq!(busca_sequencial(&lista, 2), (true, 1));
4040
assert_eq!(busca_sequencial(&lista, 0), (false, 0));
4141
}
42-
}
42+
}

src/rust/busca_sequencial_recursiva.rs

+7-7
Original file line numberDiff line numberDiff line change
@@ -1,16 +1,16 @@
1-
/*
1+
/*
22
Contribuidores
33
- Dromedário de Chapéu
4-
4+
55
A Busca Sequencial Recursiva consiste do mesmo conceito da Busca Sequencial.
6-
A diferente é que invés de iterar na lista utilizando um for por exemplo,
6+
A diferença é que ao invés de iterar na lista utilizando um for por exemplo,
77
é utilizado recursão que é resumidamente uma função que se chama N vezes com
88
mudanças no seus parâmetros te atingir ou o resultado desejado, ou um estado
99
onde não ha mais o que fazer.
1010
1111
Essa implementação é ainda mais lenta e custosa que a forma utilizando for,
1212
pois recursão utiliza muito mais memoria e processamento para ser utilizada, para
13-
poucos itens na pratica ele vai ser tão rápido quanto qualquer outro algoritmo.
13+
poucos itens na pratica ele vai ser tão rápido quanto qualquer outro algoritmo.
1414
Porem caso seja uma lista de milhares de itens este algoritmo sera um problema.
1515
*/
1616

@@ -24,8 +24,8 @@ fn busca_sequencial_recursiva(lista: &[i32], valor: i32, indice: usize) -> (bool
2424
return (false, 0)
2525
} else if lista[indice] == valor {
2626
return (true, indice)
27-
}
28-
27+
}
28+
2929
// Caso o item atual não seja o item desejado, nos chamamos a função com o índice
3030
// acrescentado, para que na próxima execução da função seja verificado o próximo
3131
// item da lista
@@ -48,4 +48,4 @@ mod test {
4848
assert_eq!(busca_sequencial_recursiva(&lista, 2, 0), (true, 1));
4949
assert_eq!(busca_sequencial_recursiva(&lista, 0, 0), (false, 0));
5050
}
51-
}
51+
}

0 commit comments

Comments
 (0)