Pular para o conteúdo principal

Postagem em destaque

BlackTDN :: Leetcode :: Resolvendo o Desafio "Longest Common Prefix" usando Harbour e TLPP

_Créditos das imagens: ChatGPT_ ### Leetcode :: Resolvendo o Desafio "Longest Common Prefix" usando Harbour e TLPP O problema [**"Longest Common Prefix"**](https://leetcode.com/problems/longest-common-prefix/description/), do Leetcode, consiste em encontrar o maior prefixo comum entre um array de strings. Se não houver prefixo comum, o resultado deve ser uma string vazia. Neste artigo, apresento as técnicas utilizadas para resolver o desafio nas linguagens **Harbour** e **TLPP**, com links para os códigos-fonte e uma explicação detalhada. --- #### Descrição do Problema Dado um array de strings, encontrar o maior prefixo comum entre todas as strings do array. **Exemplo de Entrada e Saída:** | Input |-Output-|-Expected-|-Matched-| |:----------------------------------------------------|:------:|:--------:|:-------:| | `["flower","flow","flight"]` | `fl` | `fl` ...

BlackTDN :: Implementando Funções de Criptografia com "Nós" e "Trançados"


_Créditos da imagem: Gerada com auxílio do ChatGPT_

# Implementando Funções de Criptografia com "Nós" e "Trançados"

A criptografia é um dos campos mais fascinantes da ciência da computação. Recentemente, no projeto experimental [Braided Encryption Message](https://github.com/naldodj/naldodj-braided_encryption_message), explorei como conceitos de "nós" e "trançados" podem ser aplicados na criação de algoritmos de criptografia. Este projeto, embora básico, é uma experiência rica para aprender mais sobre a implementação de funções criptográficas e algumas curiosidades relacionadas ao tema.

## Visão Geral do Projeto

O repositório contém duas peças fundamentais:

1. [Arquivo C - `c_braided_encryption_message.c`](https://raw.githubusercontent.com/naldodj/naldodj-braided_encryption_message/refs/heads/main/src/c_braided_encryption_message.c): Implementa funções de criptografia em baixo nível, manipulando diretamente a estrutura dos dados para "trançá-los".
   
2. [Arquivo Harbour - `hb_braided_encryption_message.prg`](https://raw.githubusercontent.com/naldodj/naldodj-braided_encryption_message/refs/heads/main/src/hb_braided_encryption_message.prg): Fornece uma interface de alto nível para o uso das funções escritas em C, facilitando a integração com sistemas desenvolvidos em Harbour.

### Objetivos do Projeto

- **Explorar conceitos matemáticos e lógicos** relacionados à criptografia, inspirados por estruturas como nós e trançados.
- **Praticar a integração entre linguagens** (C e Harbour), utilizando o melhor de cada uma para atingir um resultado funcional.
- **Criar um projeto didático** que possa servir como base para aprendizado e experimentação em criptografia.

## Metodologia

1. **Conceito de Nós e Trançados**
   O núcleo do projeto foi inspirado em como "nós" e "trançados" podem servir como analogias para embaralhar informações. Assim como um nó em uma corda dificulta desfazer a estrutura, os dados criptografados por este método ficam complexos de serem revertidos sem a chave correta.

2. **Implementação em C**
   A linguagem C foi escolhida para a implementação de baixo nível devido à sua performance e controle granular sobre a manipulação de memória. Este arquivo inclui:
   - Funções para gerar um padrão "trançado" nos dados.
   - Métodos para aplicar e reverter o processo de criptografia.

3. **Integração com Harbour**
   Para tornar o projeto mais acessível e demonstrar a versatilidade do Harbour, criei uma interface que encapsula as funcionalidades em C. Isso torna possível aplicar criptografia em sistemas desenvolvidos em Harbour sem necessidade de conhecimentos profundos sobre C.

4. **Teste e Validação**
   Os testes foram realizados para garantir a consistência da criptografia e a capacidade de descriptografar dados corretamente.

## Aprendizados e Curiosidades

- Trabalhar com "nós" e "trançados" é uma abordagem única para criptografia, que oferece um ponto de partida interessante para explorar novos algoritmos.
- A integração entre C e Harbour destacou a importância de bibliotecas externas e como elas podem ampliar as capacidades de uma linguagem de alto nível.
- Embora o projeto seja experimental, ele ilustra conceitos como chave simétrica e obfuscação de dados.

## Conclusão

O projeto Braided Encryption Message é mais do que uma simples implementação de criptografia. Ele representa um esforço para aprender e compartilhar técnicas que podem inspirar outros desenvolvedores. Se você está interessado em explorar o código, ele está disponível no GitHub. Sinta-se à vontade para experimentar, sugerir melhorias ou simplesmente aprender com ele.

---

[Explore o código no GitHub](https://github.com/naldodj/naldodj-braided_encryption_message)

Comentários

Postagens mais visitadas