SlideShare a Scribd company logo
1 of 17
Funções Inline 
e 
Funções 
Recursivas 
Kadzua 
Chakupadedza Kuyeri
Funções Inline 
 As funções inline servem como 
códigos a serem copiados ao lugar 
que são chamados. 
 Quando chamamos uma função inline 
em um programa, o compilador 
substitui a chamada de função pelo 
próprio código da função, adaptando 
automaticamente os parâmetros e 
retorno da função.
Sintaxe de declaração de uma 
função Inline 
 Para criar uma função inline basta fazer 
a mesma coisa que faríamos para criar 
uma função normal, a única diferença é 
que antes de começar a escrever a 
função devemos utilizar a palavra 
reservada inline. 
 Palavra _chave tipo_de_retorno nome_da_função (parâmetros) 
Exemplo:inline int kaddy(){ 
}
Funções Inline 
 A palavra-chave inline é usada em 
C++ e aplicada a uma função. Ela 
indica ao compilador que cada 
chamada para a função inline deve 
ser substituída pelo corpo desta 
função.
Exemplo de uso de Funções Inline 
 #include <iostream> 
 #include <math.h> 
 using namespace std; 
 long int quadrado (int x); 
 inline void opcao(); 
 main() { 
 int y,z; 
 cout<<"Introduza o numero para calcular o seu 
quadradon"; 
 cin>>y; 
 cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y)<<"nn"; 
 
 
 opcao(); 
 return 0; 
 }
Exemplo de uso de Funções Inline 
long int quadrado (int x){ 
return(x=pow(x,2)); 
} 
inline void opcao(){ 
int k; 
cout<<"Pretende efectuar mais um 
calculo?n1.Simt2.Naon"; 
cin>>k; 
switch(k){ 
case 1: 
main(); 
break;
Exemplo de uso de Funções Inline 
case 2: 
cout<<"Obrigado!!!"; 
break; 
default: 
cout<<"Opcao invalidann"; 
main();} 
}
Vantagem/Desvantagem do uso de 
Funções Inline 
 A vantagem é o aumento de 
desempenho (ganha-se velocidade 
com as funções inline), pois o 
programa não precisa se deslocar até 
achar a função. 
 Mas esse aumento de desempenho 
vem com um aumento no custo de 
espaço em memória.
Funções Recursivas 
 Uma função é recursiva se um 
comando no corpo da função chama 
ela mesma. 
 Qualquer função em linguagem C/C++ 
pode ser chamada de um modo 
recursivo, isto é, uma função pode 
chamar-se a si própria. 
 Para uma linguagem ser recursiva, 
uma função deve estar apta a chamar 
a si própria.
Criar Funções Recursivas 
 Para criar uma função recursiva basta 
escrever no código da função, a 
função que está sendo criada como 
se ela já tivesse sido criada antes, isto 
é, por exemplo, temos um programa 
em que sabemos que o código do 
programa está todo dentro da função 
main, se quisermos reiniciar o 
programa basta chamarmos a função 
main novamente.
Funcionamento da função 
recursiva 
 Início do programa: Chama 
automaticamente a função MAIN 
 Processos e comandos dentro do 
código: Contas com variáveis, 
condições, atribuições, etc... 
 Chama-se a função MAIN: Sem 
fechar o programa, ele chama ele 
mesmo de novo (reinicia).
Funções Recursivas 
 Dada uma função recursiva, sempre é 
possível escrever uma função 
equivalente, sem recursão.
Comparação entre função recursiva e a função 
equivalente sem recursão 
Função recursiva Código equivalente sem recursão 
#include <iostream> 
#include <math.h> 
using namespace std; 
long int quadrado (int x); 
main() { 
int y; 
cout<<"Introduza o numero para 
calcular o seu quadradon"; 
cin>>y; 
cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y); 
return 0; } 
long int quadrado (int x){ 
return x=pow(x,2); } 
#include <iostream> 
#include <math.h> 
using namespace std; 
long int quadrado (int x); 
main() { 
int y; 
cout<<"Introduza o numero para 
calcular o seu quadradon"; 
cin>>y; 
cout<<"O quadrado de "<<y<<" e 
t"<<quadrado(y); 
return 0; } 
long int quadrado (int x){ 
x=pow(x,2); 
return x; }
Exemplo de uso de Funções Recursivas 
#include <iostream> 
using namespace std; 
int main() { 
int x; 
cout<<"Veiculo:n1.Ligeiron2.Ligeiro de 
Cargan3.Pesado de passageiro e cargan4.Pesado de 
carga com atreladonn"; 
cin>>x; 
switch(x){ 
case 1: 
cout<<"Ligeiro:t10,00 meticais"; 
break;
Exemplo de uso de Funções 
Recursivas 
case 2: 
cout<<"Ligeiro de carga:t20,00 meticais"; 
break; 
case 3: 
cout<<"Pesado de passageiro e carga:t40,00 meticais"; 
break; 
case 4: 
cout<<"Pesado de carga e atrelado:t100,00 
meticais"; 
break; 
default: 
cout<<"Operacao invalidannnn"; 
main(); } 
cout<<"nnttObrigado!!!n"; 
cout<<"ttBoa viagem!"; 
return 0; }
Vantagem/Desvantagem do uso de 
Funções Recursivas 
 Usar a função recursiva torna o 
algoritmo simples. Quem faz toda a 
conta é a função. 
 Mas toda facilidade tem seu custo. 
Apesar de nosso algoritmo estar 
curto, toda vez que chamamos uma 
função leva um certo tempo para ser 
processada (a chamada de uma 
função consome tempo de 
processamento).
Fim 
Obrigado!

More Related Content

What's hot

Lógica de programação pascal
Lógica de programação   pascalLógica de programação   pascal
Lógica de programação pascalJocelma Rios
 
Logica Algoritmo 05 Repeticao
Logica Algoritmo 05 RepeticaoLogica Algoritmo 05 Repeticao
Logica Algoritmo 05 RepeticaoRegis Magalhães
 
Metabolismo de carboidratos
Metabolismo de carboidratosMetabolismo de carboidratos
Metabolismo de carboidratosRodrigo Tinoco
 
Curso básico de Algoritmos com Python
Curso básico de Algoritmos com PythonCurso básico de Algoritmos com Python
Curso básico de Algoritmos com PythonGiancarlo Silva
 
Teoria da produção
Teoria da produçãoTeoria da produção
Teoria da produçãoanatasse
 
Despesas e receitas públicas
Despesas e receitas públicasDespesas e receitas públicas
Despesas e receitas públicasrene-de-jesus
 
Componentes químicos das células
Componentes químicos das célulasComponentes químicos das células
Componentes químicos das célulasGeraldo Sadoyama
 
Clc 7 reflexão_sílvia_fernandes
Clc 7 reflexão_sílvia_fernandesClc 7 reflexão_sílvia_fernandes
Clc 7 reflexão_sílvia_fernandesSILVIA G. FERNANDES
 
Variaveis locais e globais
Variaveis locais e globaisVariaveis locais e globais
Variaveis locais e globais111111119
 
Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Karoline Tavares
 
Ebook logica-de-programacao-para-iniciantes
Ebook logica-de-programacao-para-iniciantesEbook logica-de-programacao-para-iniciantes
Ebook logica-de-programacao-para-iniciantesMarcio Lima
 
Análise de Algoritmos - Recursividade
Análise de Algoritmos - RecursividadeAnálise de Algoritmos - Recursividade
Análise de Algoritmos - RecursividadeDelacyr Ferreira
 
Bioquímica I - Variedade de funções dos hidratos de carbono
Bioquímica I - Variedade de funções dos hidratos de carbonoBioquímica I - Variedade de funções dos hidratos de carbono
Bioquímica I - Variedade de funções dos hidratos de carbonoCatarina Cruz
 
Convocatória
ConvocatóriaConvocatória
Convocatóriauamusse11
 
Reflexão 3 3274 primeiros socorros novamente corrigida
Reflexão 3  3274 primeiros socorros novamente corrigidaReflexão 3  3274 primeiros socorros novamente corrigida
Reflexão 3 3274 primeiros socorros novamente corrigidarasteiro
 

What's hot (20)

Lógica de programação pascal
Lógica de programação   pascalLógica de programação   pascal
Lógica de programação pascal
 
Logica Algoritmo 05 Repeticao
Logica Algoritmo 05 RepeticaoLogica Algoritmo 05 Repeticao
Logica Algoritmo 05 Repeticao
 
Sistema Imunitário
Sistema ImunitárioSistema Imunitário
Sistema Imunitário
 
Metabolismo de carboidratos
Metabolismo de carboidratosMetabolismo de carboidratos
Metabolismo de carboidratos
 
Curso básico de Algoritmos com Python
Curso básico de Algoritmos com PythonCurso básico de Algoritmos com Python
Curso básico de Algoritmos com Python
 
FT Módulo 578
FT Módulo 578FT Módulo 578
FT Módulo 578
 
Teoria da produção
Teoria da produçãoTeoria da produção
Teoria da produção
 
Despesas e receitas públicas
Despesas e receitas públicasDespesas e receitas públicas
Despesas e receitas públicas
 
Componentes químicos das células
Componentes químicos das célulasComponentes químicos das células
Componentes químicos das células
 
Clc 7 reflexão_sílvia_fernandes
Clc 7 reflexão_sílvia_fernandesClc 7 reflexão_sílvia_fernandes
Clc 7 reflexão_sílvia_fernandes
 
Variaveis locais e globais
Variaveis locais e globaisVariaveis locais e globais
Variaveis locais e globais
 
Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros
 
Ebook logica-de-programacao-para-iniciantes
Ebook logica-de-programacao-para-iniciantesEbook logica-de-programacao-para-iniciantes
Ebook logica-de-programacao-para-iniciantes
 
Análise de Algoritmos - Recursividade
Análise de Algoritmos - RecursividadeAnálise de Algoritmos - Recursividade
Análise de Algoritmos - Recursividade
 
Algoritmos - Vetores
Algoritmos - VetoresAlgoritmos - Vetores
Algoritmos - Vetores
 
Bioquímica I - Variedade de funções dos hidratos de carbono
Bioquímica I - Variedade de funções dos hidratos de carbonoBioquímica I - Variedade de funções dos hidratos de carbono
Bioquímica I - Variedade de funções dos hidratos de carbono
 
Saude - STC - DR1 NG3
Saude - STC - DR1 NG3Saude - STC - DR1 NG3
Saude - STC - DR1 NG3
 
Estrutura de repetição
Estrutura de repetiçãoEstrutura de repetição
Estrutura de repetição
 
Convocatória
ConvocatóriaConvocatória
Convocatória
 
Reflexão 3 3274 primeiros socorros novamente corrigida
Reflexão 3  3274 primeiros socorros novamente corrigidaReflexão 3  3274 primeiros socorros novamente corrigida
Reflexão 3 3274 primeiros socorros novamente corrigida
 

Similar to Funções inline e Recursivas

Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03thomasdacosta
 
mod3-programação-estruturada
mod3-programação-estruturadamod3-programação-estruturada
mod3-programação-estruturadadiogoa21
 
Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02thomasdacosta
 
RevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxRevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxClaudia Ferlin
 
Aula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxAula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxItamarGoncalves2
 
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Filipe Chagas Ferraz
 
Recursividade em linguagem C
Recursividade em linguagem CRecursividade em linguagem C
Recursividade em linguagem CLeonardo Lima
 
Comandos de Controle de Programa em C
Comandos de Controle de Programa em CComandos de Controle de Programa em C
Comandos de Controle de Programa em CElaine Cecília Gatto
 
Funções PHP - Criação de sites II
Funções PHP - Criação de sites II Funções PHP - Criação de sites II
Funções PHP - Criação de sites II info_cimol
 
aula intro de Python sobre Funcoes.pdf
aula intro de  Python sobre  Funcoes.pdfaula intro de  Python sobre  Funcoes.pdf
aula intro de Python sobre Funcoes.pdfGabrielEduardo16342
 
Introdução à Linguagem de Programação C
Introdução à Linguagem de Programação CIntrodução à Linguagem de Programação C
Introdução à Linguagem de Programação CJose Augusto Cintra
 

Similar to Funções inline e Recursivas (20)

Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03Algoritmos e Estrutura de Dados - Aula 03
Algoritmos e Estrutura de Dados - Aula 03
 
Funções em C
Funções em CFunções em C
Funções em C
 
mod3-programação-estruturada
mod3-programação-estruturadamod3-programação-estruturada
mod3-programação-estruturada
 
Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02Programação Estruturada 2 - Aula 02
Programação Estruturada 2 - Aula 02
 
Apostila de-arduino
Apostila de-arduinoApostila de-arduino
Apostila de-arduino
 
Modularização
ModularizaçãoModularização
Modularização
 
RevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptxRevisãoCompactaFuncoesPonteiro.pptx
RevisãoCompactaFuncoesPonteiro.pptx
 
Aula 4
Aula 4Aula 4
Aula 4
 
Funções em C
Funções em CFunções em C
Funções em C
 
Aula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptxAula 8 - Modularização e Funções.pptx
Aula 8 - Modularização e Funções.pptx
 
Linguagem C - Funções
Linguagem C - FunçõesLinguagem C - Funções
Linguagem C - Funções
 
Aula09 traducaosin110
Aula09 traducaosin110Aula09 traducaosin110
Aula09 traducaosin110
 
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
Aula - Funções (Curso de Python Básico -- FATEC SENAI MT)
 
Recursividade em linguagem C
Recursividade em linguagem CRecursividade em linguagem C
Recursividade em linguagem C
 
Comandos de Controle de Programa em C
Comandos de Controle de Programa em CComandos de Controle de Programa em C
Comandos de Controle de Programa em C
 
Funções PHP - Criação de sites II
Funções PHP - Criação de sites II Funções PHP - Criação de sites II
Funções PHP - Criação de sites II
 
aula intro de Python sobre Funcoes.pdf
aula intro de  Python sobre  Funcoes.pdfaula intro de  Python sobre  Funcoes.pdf
aula intro de Python sobre Funcoes.pdf
 
Funções e procedimentos
Funções e procedimentosFunções e procedimentos
Funções e procedimentos
 
apostila C++
apostila C++apostila C++
apostila C++
 
Introdução à Linguagem de Programação C
Introdução à Linguagem de Programação CIntrodução à Linguagem de Programação C
Introdução à Linguagem de Programação C
 

Funções inline e Recursivas

  • 1. Funções Inline e Funções Recursivas Kadzua Chakupadedza Kuyeri
  • 2. Funções Inline  As funções inline servem como códigos a serem copiados ao lugar que são chamados.  Quando chamamos uma função inline em um programa, o compilador substitui a chamada de função pelo próprio código da função, adaptando automaticamente os parâmetros e retorno da função.
  • 3. Sintaxe de declaração de uma função Inline  Para criar uma função inline basta fazer a mesma coisa que faríamos para criar uma função normal, a única diferença é que antes de começar a escrever a função devemos utilizar a palavra reservada inline.  Palavra _chave tipo_de_retorno nome_da_função (parâmetros) Exemplo:inline int kaddy(){ }
  • 4. Funções Inline  A palavra-chave inline é usada em C++ e aplicada a uma função. Ela indica ao compilador que cada chamada para a função inline deve ser substituída pelo corpo desta função.
  • 5. Exemplo de uso de Funções Inline  #include <iostream>  #include <math.h>  using namespace std;  long int quadrado (int x);  inline void opcao();  main() {  int y,z;  cout<<"Introduza o numero para calcular o seu quadradon";  cin>>y;  cout<<"O quadrado de "<<y<<" e t"<<quadrado(y)<<"nn";    opcao();  return 0;  }
  • 6. Exemplo de uso de Funções Inline long int quadrado (int x){ return(x=pow(x,2)); } inline void opcao(){ int k; cout<<"Pretende efectuar mais um calculo?n1.Simt2.Naon"; cin>>k; switch(k){ case 1: main(); break;
  • 7. Exemplo de uso de Funções Inline case 2: cout<<"Obrigado!!!"; break; default: cout<<"Opcao invalidann"; main();} }
  • 8. Vantagem/Desvantagem do uso de Funções Inline  A vantagem é o aumento de desempenho (ganha-se velocidade com as funções inline), pois o programa não precisa se deslocar até achar a função.  Mas esse aumento de desempenho vem com um aumento no custo de espaço em memória.
  • 9. Funções Recursivas  Uma função é recursiva se um comando no corpo da função chama ela mesma.  Qualquer função em linguagem C/C++ pode ser chamada de um modo recursivo, isto é, uma função pode chamar-se a si própria.  Para uma linguagem ser recursiva, uma função deve estar apta a chamar a si própria.
  • 10. Criar Funções Recursivas  Para criar uma função recursiva basta escrever no código da função, a função que está sendo criada como se ela já tivesse sido criada antes, isto é, por exemplo, temos um programa em que sabemos que o código do programa está todo dentro da função main, se quisermos reiniciar o programa basta chamarmos a função main novamente.
  • 11. Funcionamento da função recursiva  Início do programa: Chama automaticamente a função MAIN  Processos e comandos dentro do código: Contas com variáveis, condições, atribuições, etc...  Chama-se a função MAIN: Sem fechar o programa, ele chama ele mesmo de novo (reinicia).
  • 12. Funções Recursivas  Dada uma função recursiva, sempre é possível escrever uma função equivalente, sem recursão.
  • 13. Comparação entre função recursiva e a função equivalente sem recursão Função recursiva Código equivalente sem recursão #include <iostream> #include <math.h> using namespace std; long int quadrado (int x); main() { int y; cout<<"Introduza o numero para calcular o seu quadradon"; cin>>y; cout<<"O quadrado de "<<y<<" e t"<<quadrado(y); return 0; } long int quadrado (int x){ return x=pow(x,2); } #include <iostream> #include <math.h> using namespace std; long int quadrado (int x); main() { int y; cout<<"Introduza o numero para calcular o seu quadradon"; cin>>y; cout<<"O quadrado de "<<y<<" e t"<<quadrado(y); return 0; } long int quadrado (int x){ x=pow(x,2); return x; }
  • 14. Exemplo de uso de Funções Recursivas #include <iostream> using namespace std; int main() { int x; cout<<"Veiculo:n1.Ligeiron2.Ligeiro de Cargan3.Pesado de passageiro e cargan4.Pesado de carga com atreladonn"; cin>>x; switch(x){ case 1: cout<<"Ligeiro:t10,00 meticais"; break;
  • 15. Exemplo de uso de Funções Recursivas case 2: cout<<"Ligeiro de carga:t20,00 meticais"; break; case 3: cout<<"Pesado de passageiro e carga:t40,00 meticais"; break; case 4: cout<<"Pesado de carga e atrelado:t100,00 meticais"; break; default: cout<<"Operacao invalidannnn"; main(); } cout<<"nnttObrigado!!!n"; cout<<"ttBoa viagem!"; return 0; }
  • 16. Vantagem/Desvantagem do uso de Funções Recursivas  Usar a função recursiva torna o algoritmo simples. Quem faz toda a conta é a função.  Mas toda facilidade tem seu custo. Apesar de nosso algoritmo estar curto, toda vez que chamamos uma função leva um certo tempo para ser processada (a chamada de uma função consome tempo de processamento).