Vocês são felizes e não sabem... Eu, como programador das antigas (e bota antigas nisso) trabalhei muito em computadores que hoje não passariam de brinquedos. Vocês não sabem o que é programar um microcontrolador 8051 com exultantes 128 bytes (bytes mesmo, não kbytes ou Mbytes). E olhem que tinha compilador C para esse microcontrolador!... Porque eu lembrei disso? Porque existiam N problemas que seriam mais facilmente resolvidos em termos de programação utilizando recursividade, porém a recursividade impõe dois grandes problemas para a máquina: ela exige muita memória e é mais lenta. Quando você executa uma função, o compilador gera uma sequência de instruções que reserva um espaço de memória para aquela instância de função. É algo que a linguagem esconde do programador, mas que estará lá quando o código fonte for transformado em binário executável. Porém, numa função recursiva, cada vez que a função é chamada por si mesma, toda a memória reservada para aquela instância é preservada na pilha de máquina enquanto um novo espaço é aberto sobre ela na pilha. Imagine que uma função seja chamada recursivamente 100 vezes. Teremos então 100 espaços de memória empilhados um sobre o outro, esperando que a instância seguinte retorne. O gasto de memória é absurdo. Outro fato é que existe todo um código que é executado para preparar o início da execução da nova instância da função e depois outro código para finalizá-la e transferir os resultados para a instância anterior. Num computador moderno, com tanta memória e velocidade, isso não é problema, mas num PC XT com processador 8088 de 4,77 MHz e 256 kB de memória lá dos anos 80, um programa de altíssima recursividade para "mastigação de números" podia levar meia hora ou mais de trabalho, contra 5 ou 10 minutos com um código equivalente não recursivo e sem usar tanta memória. Então agradeçam. Vocês são felizes e não sabem. Posso fazer uma sugestão? É algo que com certeza é bem diferente do que vocês estão acostumados, cheira a naftalina mas é um problema bem atual. Estamos vendo que a era dos processadores que dobravam de velocidade a cada ano já passou e agora a moda é a multiplicação de cores e threads para processamento paralelo. O que pouca gente sabe é que os princípios da programação paralela (e sua irmã, concorrente) tem seus primórdios nos anos 80. Quando comecei um mestrado em nanotecnologia naquela época, eu precisava de um supercomputador (para os padrões daquela época), e para isso comecei me aventurar no mundo dos chamados Transputers, fabricados por uma empresa chamada INMOS. Esses transputers eram processadores que podiam ser colocados em paralelo numa placa mãe e automaticamente dividiam as diferentes threads paralelas e concorrentes sem necessidade de qualquer configuração. Só que para isso, esses processadores tinham uma linguagem especial, chamada OCCAM, muito parecida com C, e que oferecia suporte a funções especiais para paralelizar procedimentos. Vocês falaram neste vídeo numa comparação entre um loop e uma função recursiva, sendo que a função recursiva é uma sequência em série. A programação paralela escalável também é comparável a um loop, mas cada interação do loop é uma função que pode ser executada de forma independente por diferentes processadores em paralelo. Mas o que essa naftalina dos anos 80 tem a ver com hoje em dia? Simples: os Transputers são os bisavóes dos processadores multi-core e multi-thread. Até mesmo a ideia de processadores Xeon funcionando em paralelo na mesma placa mãe vem dos transputers. Só que se muita gente tem dificuldade em pensar um algoritmo de forma recursiva, pensar numa programação em paralelo e concorrente é de deixar o sujeito maluquinho e por isso até hoje é uma parte da ciência da computação que não avançou muito daquela época para hoje. Exemplo: uma planilha de cálculo hoje é fácil de programar dentro da progamação clássica, linear, de thread única. O defeito dessa planilha é que ela vai sempre sobrecarregar 1 thread de um core do processador. Não há ganho de desempenho ter um computador com múltiplos cores e threads para processar essa planilha. Para isso a planilha precisaria de uma programação paralela escalável. Cada célula é um processo paralelo para que possa ser processada usando todas as threads de um processador, tenha ele quantas threads e cores possuir. Só que aí temos um problema clássico de quem nasceu primeiro, o ovo ou a galinha. Uma célula só pode ser processada se todas as células das quais ela depende já foram processadas. Isso é fácil de fazer num processo linear onde colocamos as células em fila única. Porém, num programa com paralelismo, onde cada célula é executada de forma independente por diferentes processadores e cada célula tem uma velocidade diferente para ser processada, isso se torna um problema bem mais complexo de gerenciar. Porque estou tocando nesse assunto? Porque as pessoas acreditam que a tecnologia de software irá absorver essa multiplicação dos cores/threads dos novos processadores e isso não é bem assim. Aliás esta é uma das fronteiras que a engenharia da computação ainda precisa avançar para tirarmos bom proveito dela.
@BrExodusZoneDayzServers5 жыл бұрын
Mimimimimi...
@Ulusamay4 жыл бұрын
@@luiscazuriaga2628 sim,quem inventou a luz nem deu os credito pro cara que tentou a primeira vez,passou conhecimento de geração em geração kakaka o famoso foi o ultimo a descobrir,e depois só foram aprimorando
@eduardoaihara4 жыл бұрын
Caramba, a galera parece q se enfurece por causa de uma frase e ignora o restante da história. Apesar de não entender 100% do q foi dito, achei bem interessante saber um pouco como as coisas eram e mais feliz ainda por termos linguagem de alto nível e principalmente que preço de memória hoje é bem mais barato que antigamente. Obrigado por compartilhar seu conhecimento!
@thiagosantos32364 жыл бұрын
Gostei muito do conhecimento passado meu nobre.
@julioulisseslima4 жыл бұрын
Cara, não sou tão velho (tenho 36 anos), mas aprendi a dirigir em um fusca ano 78 do meu tio, daqueles que a gente tinha que acelerar com o "calcanhar" para o carro não morrer hehehehe. Ai vejo uma geração de hoje que reclama que a direção hidráulica é mais pesada que a direção elétrica... Em outras palavras obrigado pelo relato histórico, principalmente sobre a ideia de eficiência e aproveitamento de todos os recursos de um computador, pois de fato muitos "programadores", inclusive de grandes corporações, fazem testes de códigos em ambientes controlados, quando funcionam a mil maravilhas, ai soltam a aplicação para uso simultâneo por muitos usuários, e ficam sem entender o motivo do sistema travar do nada, quando ocorreram míseros 90 mil acessos simultâneos... Programar não é a parte mais difícil, entender a regra do negócio e otimizar recursos é o diferencial hoje em dia.
@i_am_batman-03093 жыл бұрын
só tenho que agradecer e reconhecer o trabalho de vocês. Obrigado por serem tão fundamentais no nosso aprendizado! :)
@Edson_Staack6 жыл бұрын
Mais um vídeo show de bola, com o casal mais simpático do universo! \o/
@codigofontetv6 жыл бұрын
Olá Edson! Do universo! Será?! rsrsrs Muito obrigada!
@BrExodusZoneDayzServers5 жыл бұрын
@@codigofontetv de acordo com o Edson 😎👊👊👊👊
@lincoln_berto2 жыл бұрын
Muito bom. Estou estudando para a faculdade e gostei bastante, me ajudou a entender mais sobre o assunto.
@joaoranulfoeloia47772 ай бұрын
Voces são maravilhosos ! Obrigado demais !
@danielcardoso63016 ай бұрын
O exemplo foi top, de verdade, simplificar pra depois complicar, são show vocês!!!!!
@BrExodusZoneDayzServers5 жыл бұрын
Casal mais top desse KZbin 😎👊🙏
@rensopa Жыл бұрын
Vocês são ótimos!!! Parabéns pelo conteúdo.
@MrWeblima6 жыл бұрын
Vocês mandam muito bem! Isso sim é didática.
@marcoantoniosilva7953 жыл бұрын
Parabéns sempre pela iniciativa de vocês em fazer este vídeo, pois me ajuda muito na minha faculdade, pois a suas explicações sua são tão claras... Parabéns.
@joanteixeira1 Жыл бұрын
Essa função enrolar desenrolou minha mente, obrigado!!
@andrejunior96165 жыл бұрын
Ajudou pra caramba na minha prova de técnicas de programação, muito obrigado!!!!
@longuinni6 жыл бұрын
Muito legal. Lembrando que recursividade nada mais é do que a quebra de um problema complexo em pequenos pedaços, em alguns casos é preciso tomar cuidado com problema de stackoverflow após estourar o empilhamento máximo do processador ou da linguagem. Muitas vezes é melhor optar por uma solução não recursiva devido a complexidade do código gerado!! Abraço CFTV! Continuem com o bom trabalho.
@wellingtonsilva-vd8bf Жыл бұрын
Excelente vídeo vocês estão de parabéns, desde 2022 iniciei meu de superior de ciência de dados, tenho 44 anos sempre amei essa área de tecnologia qual caminho para se especializar na área enquanto estudo, como buscar trabalhos nesse período.
@julianocanuto75926 жыл бұрын
Ficou muito bom o exemplo com o barbante. Gostei. Mais um ótimo vídeo. Os erros de gravação são uma comédia a parte kkkkkk
@codigofontetv6 жыл бұрын
Muito obrigado Juliano!!! :D
@carloseduardolima74436 жыл бұрын
Haha!! Ficou muito bommm! Faz sobre UI e UX Machine learning, Big data, Deep learning, Thread....
@paulocristo12 жыл бұрын
aprendi recursividade em um livro que comprei java8 e des daquela epoca sempre uso em php swift e tudo . muito bom ecenomiza e fica top
@codechannel73046 жыл бұрын
Tenho duas sugestões para vocês falarem no dicionário do programador: 1º - Web Service 2º - Biblioteca de Classe Além de dar essas sugestões quero Parabenizá-los pelos vídeos postados. Sempre fico ansioso para que postem os seus vídeos. Que bom que nós(CDFs) temos vocês como exemplo. Parabéns pelo trabalho!
@codigofontetv6 жыл бұрын
Olá Jô! Muito obrigada, ficamos muito felizes em ver depoimentos como o seu! Sugestões anotadas.
@MartioViss6 жыл бұрын
Muito bom o vídeo, obrigado.
@CamilaCPio Жыл бұрын
Coisa boa! Obrigada pelo conteúdo incrivel! Vocês são demais
@FarukAFeres6 жыл бұрын
Eu entendi recursividade com uma função fatorial. achei mais simples... function fatorial(n) { if (n
@johnsykes45134 жыл бұрын
@@morningbae valeu kkk não tinha entendido
@kratos11ist4 жыл бұрын
@@morningbae Até o num2 chegar a 1 na verdade
@thenriquedb3 жыл бұрын
classica!
@danielpolitico14473 жыл бұрын
Cara, se você está aqui lendo meu comentário você tem a sorte de ler o único lugar do planeta que tem uma definição de recursividade com lógica, sério, só eu sei explicar saporra. Esquece Google. Vamos lá: Recursividade é um fenômeno que ocorre quando uma criação possui a mesma estrutura do seu criador. Pronto, é isso. Se uma impressora imprime um papel não é recursão, mas se um dia uma impressora 3D imprimir outra impressora 3D é recursão. A reprodução dos seres vivos é recursão, pois um ser vivo possui a estrutura do seu pai. O cálculo fatorial é recursividade, porque é definido por etapas de cálculo fatorial. As pessoas têm dificuldade de explicar ou entender recursividade porque é pouco intuitiva a ideia de que uma coisa pode criar algo como a si mesma, porque para o cérebro isso a princípio pode parecer ilógico, já que, sendo assim, como será criado o primeiro criador de todos? A resposta é que o fato de uma coisa ser criada por um criador semelhante não exclui a possibilidade de o primeiro ter sido criado por um criador diferente. No exemplo das impressoras 3D a primeira delas obviamente não seria criada por outra impressora e sim por humanos. Da mesma forma, o primeiro ser humano não foi criado por outro, mas por uma variação genética de outra espécie ou por Deus, se preferir. Esse conceito é importante porque quem entende consegue subir um patamar na capacidade de criar e resolver questões, especialmente no empreendedorismo (a ideia de uma impressora imprimindo outra não é disruptiva?), na computação onde o uso de recursividade é corriqueiro, também para linguistas e filósofos, mas também em qualquer área. Ainda aproveitando o exemplo, o sujeito que criou o conceito de fatorial só pôde fazê-lo por entender o conceito, pois, por exemplo, fatorial de cinco é cinco vezes o fatorial de quatro e fatorial de quatro é quatro vezes o fatorial de três e assim consecutivamente até fatorial de 1 que por definição é um, que é a condição de parada. Então existe a chance de você ter aprendido algo aqui que pode ser útil na sua vida.
@FarukAFeres3 жыл бұрын
@@danielpolitico1447 quando eu vi essa função de fatorial foi uma epifania. Eu gosto de matemática e ver 4~5 aulas de matemática no ensino médio ser representada por 4 linhas de código foi mágico. O seu texto é lindo e concordo 100% com ele mas programação é complicado quando o indivíduo tem que se empenhar pra conseguir esses momentos de epifania que eu comentei. Infelizmente ele só vai fazer sentido pra quem já entendeu recursividade.
@bfzff76083 жыл бұрын
Ótima explicação!
@brunofelix54346 жыл бұрын
Ótimo vídeo... conheci a pouco tempo o canal de vcs e já vi quase todos os vídeos... adorei vcs.
@razor0wn3d6 жыл бұрын
Mandaram bem.
@Johnnie_MG6 жыл бұрын
Sou provável formando em ciência da computação 2018, adoro os vídeos de vocês, estou na área de jogos, vocês tem dicas dessa área? Grande abraço.
@codigofontetv6 жыл бұрын
Olá Johnnie, muito obrigada! Ainda não temos um conteúdo específico pra desenvolvedores de games, mas em breve teremos. Até lá!
@jaderpacheco95856 жыл бұрын
Vocês ajudam muito programadores iniciantes (como eu). Obrigado casalzão da por***
@codigofontetv6 жыл бұрын
Muito obrigada Jader!!!
@adrianorigonato8082 Жыл бұрын
já tá senior, jader?
@joaopedrogomesdesena8674 Жыл бұрын
já deu tempo né? kkkkkk@@adrianorigonato8082
@danielschneider52513 жыл бұрын
Estou aprendendo python. Hoje estava escrevendo um código e me deparei com um problema. A lógica não estava acontecendo da maneira que eu esperava. Consegui solucionar essa questão aplicando a recursividade. Mais uma lição de aprendizado para o meu banco de dados neural kkkk
@paulosoads8565 жыл бұрын
Quer ver uma recursão legal? faz assim: -Abra o bloco de notas e escreva start cmd -Salve o arquivo como o nome cmd.bat -abra o arquivo Esteja com gerenciador de tarefas aberto. Você vai precisar
@Ulusamay4 жыл бұрын
mano ala tu é um Corno kakakaka fiz isso fez um loop da poxa,quase eu não consiguia fechar os prompts ala kakakakaakak mas foi top dá uma ideia de virus simples kdaskkas
@tiagodmota58403 жыл бұрын
Quebrou uma das leis, não é recursividade autêntica.
@RobsonAlvesJJ6 жыл бұрын
Foi muito bom parabéns.....
@Samuel-Ferreira-Inocencio7 ай бұрын
Em 2024 estou aprendendo programação com apoio da Alura. Recursividade ainda é um quebra-cabeça que estou desvendando.
@marciogomes3090 Жыл бұрын
Eu só entendi com a metáfora da linha lakakakakakkaka Obrigado! Adorei
@JoseChiniapala-jt1fy8 ай бұрын
Vocês me ajudaram muito
@jonatanmsd Жыл бұрын
Video top! Boa aula dmais!!!
@gabrieldavid7664 Жыл бұрын
Muito bom, obrigado pela aula!
@alexiasantos6249 Жыл бұрын
Muito obrigada ! foi muito util
@flavioaugusto41066 жыл бұрын
Muito bom parabéns!!
@pr.rafaelnascimento Жыл бұрын
Excelente explicação
@oriadne6 жыл бұрын
Boa tarde, belo trabalho. Mas o exemplo do barbante cria um erro de lógica, pois a ideia da recursividade é dividir o problema até que ele não possa mais ser dividido ai só então vir retornando a solução das pequenas partes até a primeira chamada, no caso do barbante se a função enrolar for executada a cada chamada o problema está a se resolver de forma direta e não recursiva.
6 жыл бұрын
O exemplo do barbante é um laço comum
@codigofontetv6 жыл бұрын
Oi oriadne! Faz sentido se comentário. Poderíamos ter mostrado o exemplo apenas fazendo as medições e só ao fim da última medição possível "voltar" com as chamadas enrolando o barbante, de uma vez só. Sem dúvida ficaria melhor. :D Muito obrigado pelo seu feedback.
@heightSky Жыл бұрын
muito bom
@debaixodatampa4 жыл бұрын
Ô menina... Eu sou bom nessa função ENROLAR aí hein!!! hahahahah Muito obrigado pelo vídeo elucidativo!
@fontanadnb6 жыл бұрын
Faltou dizer das desvantagens da recursividade como alta taxa de alocação de memória, dependo do caso. A recursividade as vezes parece a forma menos complexa de resolver o problema, mas pode causar grandes perdas de performance, etc, etc, etc.
@diadetediotedio69182 жыл бұрын
Isso não funciona assim.
@boscherof6 жыл бұрын
Tenho sonho em entrar profissionalmente nesse mundo, mas como? É muito abrangente ! Ó Deus da programação, me ajuda !
@kratos11ist4 жыл бұрын
E aí, conseguiu emprego na área depois de 2 anos?
@canon618376 жыл бұрын
Muito bom essa serie de videos!! parabéns!
@codigofontetv6 жыл бұрын
Muito obrigado Jeh! :D
@andresousa68205 жыл бұрын
Uma boa forma de treinar Recursividade são alguns dos problemas usados em competições de programação (como a OBI e a Maratona de Programação). Já ouviram falar da Olimpíada Brasileira de Informática (OBI) ou da Maratona de Programação ? são competições voltada para alunos tanto do Ensino Fundamental e Médio (OBI) quanto para alunos de faculdade (Maratona) com foco em programação competitiva (algoritmos e estruturas de dados principalmente). Vai muito em linha com o conteúdo do canal de vocês. Pode nos ajudar a difundir as competições de programação pelo Brasil ? Acredito que está bem alinhado com o conteúdo do seu canal e seria de grande ajuda. Caso haja interesse entre em contato.
@caldasyahoo Жыл бұрын
Cara vc me deu a dica de ouro para o que eu estava procurando, grato
@matheuscastro41244 жыл бұрын
Adiciona no dicionário o termo "DLL - Dynamic Link Library"
@catalunham.j.18954 жыл бұрын
Fiz um estes dias, para um caso de navegacao em cat e subcat de indices...
@rodrigocamargo1981Ай бұрын
Pode se dizer que a recursividade é resumir um problema matemático que antes era extenso e que estava deixando o processamento dos dados lentos para um processamentos de dados mais eficiente?
@eduardolima12276 жыл бұрын
Eu sinto falta de um canal ou assunto que vá além do abordado aqui, sou formado em Engenharia de Computação à 12 anos mas trabalho à pelo menos 21 anos na área, desde década de 90, e não há praticamente nada que ultrapassa o academicismo no KZbin, deixo esta dica para este canal, pois as experiências cotidianas na área computacional e de mercado têm muito a dizer e a contribuição disto é de grande valor, mas caso saibam de algum canal neste aspecto que possam indicar, por favor me digam o link, no mais parabéns pelo trabalho, vou ajudando com os likes, na medida do possível.
@codigofontetv6 жыл бұрын
Oi Eduardo, muito obrigado pelo seu comentário. Quando tiver um tempinho assista outros vídeos do nosso canal. Temos muitos vídeos, principalmente os vlogs, onde falamos mais do dia a dia de nossa profissão, inclusive, esse é um dos grandes objetivos do canal. Grande abraço e obrigado pela sua companhia por aqui.
@eduardolima12276 жыл бұрын
@@codigofontetv Eu que agradeço, a iniciativa de vocês é de grande valor, parabéns!
@ermesondesousaflamengo92936 жыл бұрын
olá gostaria de saber qual é o melhor programa de software para se especializar e iniciar na carreira na programador ?(sei que essa pergunta não tem haver com vídeos ,mas só uma dúvida minha )grato pela resposta
@marceloh6206 Жыл бұрын
03:55 vocês são chatos, mas amamos vocês
@geovannaaraujo28494 жыл бұрын
5:09 Como ficaria esse exemplo em Python? Alguém pode me responder por favor?
Ótimo vídeo! Agora... Prq essa quantidade de canetas? kk
@carlosdemetrio26476 жыл бұрын
Tava aprendendo isso semana passada na faculdade kkk
@codigofontetv6 жыл бұрын
Que coincidência! Espero que o conteúdo tenha complementado as aulas. Abraços.
@jerryaugusto956 жыл бұрын
INTEROPERABILIDADE nos próximos vídeos, por favor!
@andreylima54693 жыл бұрын
Então podemos dizer que a recursividade é um laço?
@tiagodmota58403 жыл бұрын
Aparentemente se comporta como um laço, mas por debaixo dos panos cada chamada recursiva armazena valores na pilha de chamadas, e quando o caso base é satisfeito a recursão acontece de forma reversa até chegar na função pai de todas as chamadas, os resultados vão sendo desempilhados e retornados um a um. Pra entender plenamente você tem de estudar Algoritmos e Estruturas de Dados.
@Bitcoio4 жыл бұрын
Toda recursão gera uma pilha?
@tiagodmota58403 жыл бұрын
Até onde eu sei sim. Mas consulta a documentação da linguagem pra ter certeza de como o compilador vai lidar com isso.
@OsTaualegres4 жыл бұрын
3:58 não tem recursividade nenhuma nessa relação ❤️
@MatheusdaRochaSena Жыл бұрын
Gente, Muito bom o vídeo mas eu realmente não entendi a aplicação da função multiplica.... Eu consigo ver o num2( 4 ) reduzindo, mas eu não vejo o 5 somando. -> Toda vez que a função é chamada o num2 reduz 1 ao entrar no novo parâmetro funcionando como o passo de um laço. parando no else if, quando o número for 1, porém.... ela retorna para onde? kkkk fiquei confuso, por exemplo, se ela foi chamada por ela mesma 5 vezes ela dá return para a quarta, ou para o programa principal?...... Acho que eu tô pegando, alguns neurônios cansados a mais e eu entendo a abstração até o fim da tarde... -> Mas o que eu não visualizo é o "return (num1 + multiplica(num1, num2 - 1));" Eu tô estudando recursividade agora, juntando tudo que eu sei, o programa entraria na função antes de somar o num1 ( 5 ), não somando ele, reduzindo o 4 mas não somando o 5, gerando um erro. Com certeza estou errado, mas realmente não consigo ver o num1 somando ali, talvez por eu ter começado recursividade agora. Se alguém puder ajudar nessa dúvida agradeceria muito.
@juansoares21086 жыл бұрын
Estou com dúvidas será que alguém pode me responder? Qual é a diferença entre C C++ e C#? Desde já agradeço!
@nasrudin36 жыл бұрын
Juan, C é uma LP do paradigma estruturado, compilada, criada em 1972 por Dennis Ritchie no Bell Labs - que na época pertencia à AT&T - considerada mãe de inúmeras LPs modernas. C++ é uma LP do paradigma orientado a objetos, compilada, baseada em C, criada por Bjarne Stroustrup em 1985 no Bell Labs. C# é uma LP do paradigma orientado a objetos, híbrida - ou seja, é primeiro compilada e depois interpretada - lançada em 2002 pela Microsoft. Outra LP importante é Java - orientada a objetos, híbrida - lançada pela Sun Microsystems em 1995, e hoje desenvolvida pela Oracle.
@tiagodmota58403 жыл бұрын
C veio antes das duas (C++ e C#). Ela foi feita em 1972 num laboratório de pesquisa e inovação subsidiária da Nokia, chamado AT&T Bell Laboratories, com o propósito de criar um sistema operacional para o computador PDP-11, esse sistema é o Unix, a base do Linux atual, feito por Linus Torvalds. (Bell Laboratories foi responsável por criar uma série de tecnologias usadas hoje, como os transistores, os LEDs, etc. É um verdadeiro mar de inovações importantes) C++ surgiu com o propósito de ser um C com classes, ou seja, um C com programação orientada a objetos, mas ao longo dos anos ela se tornou uma linguagem recheadada de mais paradigmas e completamente à parte, apesar de ainda ser possível misturar código C com C++ e os seus compiladores suportarem código em C puro. C# foi criada pela Microsoft pra competir com o Java , não tem nada a ver com C e C++, apesar destas duas terem influenciado a criação de Java pela Sun Microsystems, posteriormente comprada pela atual Oracle. Assim como Java não tem nada a ver com JavaScript, C# não tem nada a ver com C/C++.
@AP-gc5ss6 жыл бұрын
+Código Fonte TV serio mesmo que você não vão explicar o algortimo que mostraram???
@jonaspetty87672 жыл бұрын
Eu entendo a recursividade, mas minha mente da muito nó na hora de refatorar ou até mesmo de implementar, putz grila
@phelipefox6 жыл бұрын
Por que há tantas canetas em teus bolsos?!?
@gabrielsantos-mo2nu10 ай бұрын
tó vendo isso em java e não tó entendendo essa lógica
6 жыл бұрын
Porque não usar um while para resolver um problema de recursividade?
@tiagodmota58403 жыл бұрын
Problemas que são melhores resolvidos com recursividade são mais chatos de entender, eles só apresentaram o conceito com exemplos simples que com while daria pra resolver mais facilmente mesmo.
3 жыл бұрын
@@tiagodmota5840 acho que em baixo nível, faz diferença. Mas a maioria fica muito mais simples de visualizar o problema sem recursividade. Ai fica a se pensar, deixar simples ou veloz
@tiagodmota58403 жыл бұрын
@ Alguns problemas ficam mais complexos de serem resolvidos com while, um exemplo é rotação de nós em Árvores Binárias de Busca. Recursividade consome mais memória e é mais lenta que um loop comum, mas facilita a implementação de problemas que possuem uma natureza recursiva inerente: "Ao tentar resolver o problema, encontrei obstáculos dentro de obstáculos. Por isso, adotei uma solução recursiva." - Aluno S.Y.
3 жыл бұрын
@@tiagodmota5840 baita exemplo. Muito mais simples trabalhar com ponteiros em recursividade
@EmanoelLucas85523 жыл бұрын
na verdade, tem problema que só dá pra ser resolvido com recursividade
@vendettabr20224 жыл бұрын
Putz grilo, ainda nao entendi como funciona recursividade, q saco mano >:( Ah deixa quieto! Vou rebobinar minhas fita cassete aqui...
@pedrolobo10816 жыл бұрын
Fiquei esperando a caneta no exemplo =/
@wellingtonaraujo54183 жыл бұрын
boa aula =) asudhasuidasiud
@LucasNunesK6 жыл бұрын
Recomendo esse vídeo sobre recursividade: kzbin.info/www/bejne/hHzcnnR6adV9kKs
@codigofontetv6 жыл бұрын
😱😱😱 gênio!!!
@tiagodmota58403 жыл бұрын
Já eu recomendo esse vídeo sobre recursividade: kzbin.info/www/bejne/hHzcnnR6adV9kKs
@andreranulfo-dev86075 жыл бұрын
Poxa... Citar as três leis da robótica e citar "Eu, Robô" sem falar no seu autor, Isaac Azimov, foi quase um sacrilégio. Poderiam ter pelo menos citado que o filme foi baseado nesse clássico da ficção-científica.
@andreranulfo-dev86075 жыл бұрын
Poxa... Citar as três leis da robótica e "Eu, Robô" sem falar no seu autor, Isaac Azimov, foi quase um sacrilégio. Poderiam ter pelo menos citado que o filme foi baseado nesse clássico da ficção-científica.
@1919Reid Жыл бұрын
function fatorialComRecurssividade(n) { if (n === 0) return 1 return n * fatorialComRecurssividade(n - 1) } console.log(fatorialComRecurssividade(5)) /* NOTA!!! EU SO ESCREVI "n = 3", por exemplo, para lembrar que o numero se refere a "n". ordem dos acontecimentos-> 5 * ((n = 5)-1) presta a a atenção na primeira vez "n" vale 5, ok; 4 * ((n = 4)-1) na segunda vez "n" vale 4 os dois "n" tanto o do calculo de multiplicação quanto o do "n"-1; 3 * ((n = 3)-1) depois vale 3 2 * ((n = 2)-1) depois vale 2 1 * ((n = 1)-1) e por fim vale 1 //recurssividade ((n = 1)-1) = 0 ativa o booleano-> if (n === 0) return 1 //lembrando estou chamando novamente a função do inicio então "n" assume o valor do resultado do retorno anterior, no caso n = 1 1 * (1) = 1 essa parte aqui -> 2 * ((n = 2)-1) esta esperando para receber o retorno do resultado da recurssão anterior ou seja 1, ficando-> 2 * (1) que resulta em 2 essa parte aqui -> 3 * ((n = 3)-1) esta esperando para receber o retorno do resultado da recurssão anterior anterior ou seja 2, ficando -> 3 * (2) que resulta em 6 essa parte aqui -> 4 * ((n = 4)-1) esta esperando para receber o retorno do resultado da recurssão anterior anterior ou seja 6, ficando -> 4 * (6) que resulta em 24 essa parte aqui -> 5 * ((n = 5)-1) esta esperando para receber o retorno do resultado da recurssão anterior anterior ou seja 24, ficando-> 5 * (24) = que resulta por fim em 120