Edsger Wybe Dijkstra (nasceu em 11 de maio de 1930, Rotterdam, Holanda — faleceu em 6 de agosto de 2002, Nuenen, Holanda) tinha uma mãe matemática e um pai professor de química. Ele foi um importante cientista da computação holandês, o qual ficou principalmente conhecido pelo algoritmo desenvolvido por ele que calcula o caminho mais curto entre dois vértices em um grafo (Algoritmo de Dijkstra).
Estudou matemática e física na Universidade de Leiden para se formar em física teórica, mas posteriormente percebeu que seu interesse era pela ciência da computação. Em 1951, após seu pai encontrar um curso de programação de computadores, Dijkstra imaginou que essa habilidade seria importante em sua graduação como físico teórico e decidiu assistir às aulas. Durante as aulas, viu-se apaixonado pelos desafios que a computação trazia e entrou em um dilema entre continuar estudando física ou estudar programação.
Por meio de conhecidos, foi-lhe oferecido um emprego como programador no Centro de Matemática do Instituto Nacional de Pesquisa em Matemática e Ciência da Computação em Amsterdam, e começou a trabalhar lá em 1952. Esse feito o tornou, oficialmente, o primeiro programador nos Países Baixos.
Mas em certo momento, ele teve que escolher entre continuar na física teórica ou passar para a computação, escolhendo a segunda opção. Entretanto, continuou seus estudos de física na Universidade de Leiden, até graduar-se em 1956. Depois disso, mudou-se por definitivo para Amsterdam. No ano seguinte, ele se casou com Maria C. Debets, com quem teve 2 filhos e uma filha.
Em 1973, Dijkstra se tornou pesquisador da Burroughs Corporation, que, na época, era uma das maiores empresas de informática. Trabalhou para essa empresa de casa com arquitetura de computadores, visitando de vez em quando as filiais da empresa nos Estados Unidos. Em 1984 ocupou uma cadeira em ciência da computação na Universidade do Texas, na qual se aposentou em 1999.
Dijkstra morreu na Holanda, aos 72 anos de idade, após uma duradoura luta contra o câncer.
Dijkstra ficou amplamente conhecido por sua solução de 1959 para o problema da teoria dos grafos do caminho mais curto entre dois nós de uma rede, que ele criou em 20 minutos enquanto estava sentado tomando café com sua noiva. Esse Algoritmo de Dijkstra ainda é usado nos dias atuais para determinar o caminho mais rápido entre dois pontos, como no planejamento de voos e em roteamento da rede.
Figura 2
Durante mais de 40 anos como cientista da computação, incluindo cargos na academia e na indústria, Dijkstra fez contribuições significativas para muitas áreas da ciência da computação, entre elas:
No final da década de 50, ele ajudou a desenvolver o compilador para a linguagem ALGOL60. Entre as novas funcionalidades da linguagem, a recursividade era a que mais chamava atenção, e com isso introduziu o conceito de pilha (estrutura de dados) na tradução de programas recursivos. Na década de 60, Dijkstra acreditava fielmente que linguagens de alto nível não deveriam utilizar o comando GOTO, sua opinião era tão forte que chegou a escrever uma carta a respeito em 1968. Também nessa década, ele propôs o mecanismo de semáforos, identificou o problema do deadlock, propondo o algoritmo do banqueiro para preveni-lo.
Entretanto, sua maior contribuição é, sem dúvidas, seu algoritmo que calcula o caminho de custo mínimo entre vértices de um grafo (denominado Algoritmo de Dijkstra). Após escolher um vértice como raiz, este algoritmo calcula o custo mínimo deste vértice para todos os demais vértices do grafo. Ele é bastante simples e tem um bom nível de performance. Entretanto, ele não garante a exatidão da solução caso haja a presença de arcos com valores negativos.
Por todas essas contribuições duradouras e fundamentais no campo computacional, Dijkstra recebeu os seguintes prêmios:
Figura 3
Figura 4