SlideShare une entreprise Scribd logo
1  sur  17
Télécharger pour lire hors ligne
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!

Contenu connexe

Tendances

Pointers in c
Pointers in cPointers in c
Pointers in cMohd Arif
 
Functions in c language
Functions in c languageFunctions in c language
Functions in c languageTanmay Modi
 
RECURSION IN C
RECURSION IN C RECURSION IN C
RECURSION IN C v_jk
 
Types of function call
Types of function callTypes of function call
Types of function callArijitDhali
 
C programming - Pointers
C programming - PointersC programming - Pointers
C programming - PointersWingston
 
Aula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem CAula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem Cprofjr
 
16717 functions in C++
16717 functions in C++16717 functions in C++
16717 functions in C++LPU
 
Function overloading and overriding
Function overloading and overridingFunction overloading and overriding
Function overloading and overridingRajab Ali
 
Data Type in C Programming
Data Type in C ProgrammingData Type in C Programming
Data Type in C ProgrammingQazi Shahzad Ali
 
Aula 5 - Estruturas de seleção encadeada - parte 2
Aula 5 - Estruturas de seleção encadeada - parte 2Aula 5 - Estruturas de seleção encadeada - parte 2
Aula 5 - Estruturas de seleção encadeada - parte 2Pacc UAB
 

Tendances (20)

Pointers
PointersPointers
Pointers
 
Pointers in c
Pointers in cPointers in c
Pointers in c
 
C function presentation
C function presentationC function presentation
C function presentation
 
Functions in c language
Functions in c languageFunctions in c language
Functions in c language
 
RECURSION IN C
RECURSION IN C RECURSION IN C
RECURSION IN C
 
Introduction to Python Basics Programming
Introduction to Python Basics ProgrammingIntroduction to Python Basics Programming
Introduction to Python Basics Programming
 
Function lecture
Function lectureFunction lecture
Function lecture
 
Types of function call
Types of function callTypes of function call
Types of function call
 
Pointer to function 1
Pointer to function 1Pointer to function 1
Pointer to function 1
 
C programming - Pointers
C programming - PointersC programming - Pointers
C programming - Pointers
 
Aula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem CAula sobre matrizes - Linguagem C
Aula sobre matrizes - Linguagem C
 
16717 functions in C++
16717 functions in C++16717 functions in C++
16717 functions in C++
 
Pointers in C
Pointers in CPointers in C
Pointers in C
 
Functions in C
Functions in CFunctions in C
Functions in C
 
Function overloading and overriding
Function overloading and overridingFunction overloading and overriding
Function overloading and overriding
 
Control statements in c
Control statements in cControl statements in c
Control statements in c
 
Function Pointer
Function PointerFunction Pointer
Function Pointer
 
Data Type in C Programming
Data Type in C ProgrammingData Type in C Programming
Data Type in C Programming
 
Break and continue
Break and continueBreak and continue
Break and continue
 
Aula 5 - Estruturas de seleção encadeada - parte 2
Aula 5 - Estruturas de seleção encadeada - parte 2Aula 5 - Estruturas de seleção encadeada - parte 2
Aula 5 - Estruturas de seleção encadeada - parte 2
 

Similaire à 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
 
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
 
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
 

Similaire à 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)
 
Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros Linguagem C - Funções e ponteiros
Linguagem C - Funções e ponteiros
 
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++
 

Dernier

Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...
Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...
Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...xokece8239
 
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdf
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdfGerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdf
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdfLeonardo Martins
 
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxFASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxhefifo4687
 
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...migorof964
 
Quando se trata de inteligência emocional, encontramos inúmeras definições na...
Quando se trata de inteligência emocional, encontramos inúmeras definições na...Quando se trata de inteligência emocional, encontramos inúmeras definições na...
Quando se trata de inteligência emocional, encontramos inúmeras definições na...migorof964
 
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...migorof964
 
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...migorof964
 
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...hefifo4687
 
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxFASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxmigorof964
 

Dernier (9)

Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...
Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...
Com base na imagem apresentada e em seus conhecimentos sobre a implementação ...
 
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdf
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdfGerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdf
Gerenciando_pequenos_projetos_com_Notion_Leonardo_Martins_AgileTrends2024.pdf
 
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxFASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
 
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...
Você já agiu sem pensar Muitas vezes, somos precipitados, porque o comportame...
 
Quando se trata de inteligência emocional, encontramos inúmeras definições na...
Quando se trata de inteligência emocional, encontramos inúmeras definições na...Quando se trata de inteligência emocional, encontramos inúmeras definições na...
Quando se trata de inteligência emocional, encontramos inúmeras definições na...
 
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...
O horário político obrigatório suscitou inúmeros questionamentos em D. Matild...
 
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...
Na unidade I, Valenciano (2024) cita três lições para a melhor compreensão da...
 
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...
Para Aguera (2008), a emoção pode ser representada por impulsos que podem ser...
 
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docxFASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
FASE A1 de 2024 - Logica de Programacao e Algoritmos.docx
 

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).