SlideShare una empresa de Scribd logo
ELO320 1
C++
Biblioteca Estándar de Templates
Standar Template Library
Agustín J. González
ELO320
ELO320 2
Características de C++
• El propósito de este material es rápidamente
revisar todas características de C++ que
ustedes probablemente han encontrado
• Si ustedes han aprendido otro lenguaje,
podrán ubicarse rápidamente
• Referencia: Timothy Budd, “Data Structures
in C++, using the Standard Template
Library”, Addison Wesley 1998. Esta en
nuestra biblioteca.
ELO320 3
Comentarios y Constantes
• Hay dos tipos de comentarios
// desde doble slashes hasta el final de la línea
/*
Comentarios que se extienden
varias líneas
*/
• Los comentarios deberían usarse intensamente por documentación.
• Constantes:
• hay varios tipos de constantes
integers -1,12,-37
enteros octales 014
enteros hexadecimales 0xFF 0xC
punto flotante 3.14158, 2.7e14
caracteres ‘a’ ‘n’
string “abc”
• sufijos pueden ser aplicados a constantes
u por unsigned
l por long
ELO320 4
Variables, Tipos, Valores y Declaraciones
• Una variable es una localización con nombre que almacena un valor de
cierto tipo.
• Variables son creadas usando una sentencia de declaración, la cual
describe también el tipo asociado.
int a,b,c; // declara tres enteros
• La declaración puede ser combinada con inicialización:
double pi = 3.1415926;
• Tipos Fundamentales de Datos
• Enteros int
• punto flotante: double, float
• Caracter: char
• Modificadores que pueden ser usados con tipos fundamentales
signed,, unsigned
short, long (posiblemente) mas pequeño o mas grande que estándar.
ELO320 5
Mas tipos de Datos
• Variables Booleanos (bool)son verdaderas o falsas (true/false)
• Valores enumerados son definidos indicando el rango en forma
explícita
enum month{January, February, March, April, May, June, July,August,
September, October,November, December};
months workingMonth, vacationMonth;
months summerMonth = August;
• Variables y Asignaciones
double f, c; // Temperatura Fahrenheit y Celsius
c = 43;
f = (c * 9.0) / 5.0 + 32;
• Operadores binarios pueden ser combinados con asignaciones
i += 5; // equivale a i = i+5;
• Otra anotación compacta es:
i++
ELO320 6
Operadores
ELO320 7
Stream de I/O
• El operador de corrimiento izquierda y derecha tienen distinto
significado cuando son usados con valores de stream.
• El stream mas común es el asociado con la consola de entrada y salida.
cout << "the Fahrenheit equivalent of " << c <<
" is " << f << "n";
cin >> c; // get a new value of c
cout << "the Fahrenheit equivalent of " << c <<
" is " << f << "n";
• El Operador >> trabaja or efecto lateral, cambiando la expresión del
lado derecho. El resultado puede ser convertido a boolean para probar
si la estrada fue exitosa.
int sum = 0;
int value;
while (cin >> value) {
sum += value;
}
cout << "sum is " << sum << "n";
ELO320 8
Punteros
• Los punteros pueden ser usados de las siguientes formas:
• Punteros pueden ser usados con subíndices (tiene sentido si
apuntan a arreglos, pero esto no es chequeado)
• Pueden ser des-referenciados, usando el operador *
• Pueden combinar des-referencia con accesos a campos,
usando operador ->
• Pueden usar sumas, p+i es la dirección de p[i]
ELO320 9
Sentencias condicionales
month aMonth;
...
if ((aMonth >= June) && (aMonth <= August))
isSummer = true;
else // es opcional
isSummer = false;
ELO320 10
Sentencia Switch
switch (aMonth) {
case January:
highTemp = 20;
lowTemp = 0;
break;
case February:
highTemp = 30;
lowTemp = 10;
break;
...
case July:
highTemp = 120;
lowTemp = 50;
break;
default:
highTemp = 60;
lowTemp = 20;
};
ELO320 11
Bucles de repetición
WHILE
c = 0;
while (c <= 100) {
cout << "Celsius " << c << " is Fahrenheit " <<
((9.0 * c) / 5.0 + 32) << "n";
c += 10;
}
FOR
for (c = 0; c <= 100; c += 10) {
cout << "Celsius " << c << " is Fahrenheit " <<
((9.0 * c) / 5.0 + 32) << "n";
}
for (int i = 0; i < 12; i++) {
cout << "i: " << i << " i squared " << i*i << "n";
}
ELO320 12
Arreglos
• Es una colección de tamaño fijo de valores del mismo tipo.
// declare an array of twelve integer values
int Temperatures[12];
// now assign all values
Temperatures[0] = 0;
Temperatures[1] = 10;
Temperatures[2] = Temperatures[1] + 15;
...
• Pueden ser inicializados
string MonthNames[12] = {"January", "February",
"March", "April", "may", "June",
"July", "August", "September", "October",
"November", "December" };
• Arreglos Multidimencionales
double matrix[10][20];
matrix [i][j] = matrix [i-1][j+1] + 1;
ELO320 13
Arreglos y Punteros
• Hay una relación muy cercana entre arreglos y punteros
• El nombre del arreglo es tratado como un puntero.
• Punteros pueden usar subíndices, como si fueran arreglos(aun si no lo son)
• MonthNames+3 es legal, es la dirección de MonthNames[3].
• Arreglos como Argumentos
• Cuando son usados como argumentos no necesitamos especificar el tamaño.
int arraySum (int values[ ], int n)
// compute sum of array values[0] .. values[n-1]
{
int result = 0;
for (int i = 0; i < n; i++) {
result += values[i]
}
return result;
}
ELO320 14
Estructuras
• Es una colección de campos que no requieren tener el mismo tipo.
struct person {
string name;
int age;
enum {male, female} sex;
};
• El acceso es via el operador .
person employee;
employee.name = "sam smith";
employee.age++;
if (employee.sex == male)
...
ELO320 15
Funciones
• Una función encapsula un conjunto de acciones.
int Fahrenheit(int cTemp)
{
return (cTemp * 9.0) / 5.0 + 32;
}
• Partes:
Encabezado con tipo retornado, nombre y argumentos.
Cuerpo con sentencias a ejecutar.
• Valor retornado puede ser void (ningún valor)
• Una función prototipo es una declaración pero sin definición.
// prototype for Fahrenheit -- definition occurs later
int Fahrenheit (int);
ELO320 16
Variables Locales
• Variables al interior de la función existen solo cuando la función es
ejecutada, desaparecen cuando la función retorna. La excepción a esta
regla son las variables estáticas.
• Si suponemos que la función A llama a B y esta llama a C, podemos
imaginar en el stack del proceso usuario:
Variables locales de C
Variables locales de B
Variables locales de A
• Si B fuera recursiva y llamara a si misma una vez antes de llamar a C,
tenemos:
Variables locales de C
Variables locales de B
Variables locales de B
Variables locales de A
ELO320 17
El evento Main
• Todo programa debe incluir un procedimiento main, el cual es el punto
de partida de la ejecución.
# include <iostream>
void main() {
// program to write table of squares
cout << "Table of Squaresn";
for (int i = 0; i < 12; i++) {
cout << "i: " << i << " i squared " << i*i << "n";
}
}
ELO320 18
Archivos includes
• Muchas estructuras de datos requieren que uno defina un archivo de
inclusión antes que podamos usarlas.
Propósito Nombre
stream input/output iostream
funciones matemáticas math.h
números complejos complex
valores booleanos bool.h
algoritmos genéricos algorithm
Abstracción vector vector
Abstracción lista list
Abstracción conjunto set
Abstracción mapa map

Más contenido relacionado

PDF
2.introducción a las aplicaciones en c++
PDF
Informatica3 de 3 apuntes eii año 24/25.
DOCX
Informe técnico 1
PDF
Guia 5 dev c++
PDF
Doc tutorial-c++
PDF
Doc tutorial-c++
2.introducción a las aplicaciones en c++
Informatica3 de 3 apuntes eii año 24/25.
Informe técnico 1
Guia 5 dev c++
Doc tutorial-c++
Doc tutorial-c++

Similar a BasicC++.ppt (20)

PPT
Introduccion a c++
DOC
Mynor Alexander Hernandez Canuz
DOC
Investigacion 1
PDF
Curso de C++ (2014)
PPTX
Jorge salazar 4 to b xd
PPTX
Jorge salazar 4 to b xd
PPTX
Jorge salazar 4 to b xd
PPTX
Introducción
PPTX
Introducción
DOCX
Tutorial C++
PPT
Lenguajec 1
PPTX
Introducción al lenguaje c
DOCX
A1 u1-16230227
PDF
C facil de_v2
PDF
Informe tecnico victor_uex
DOCX
Instituto tecnológico particular
PPTX
Tutorial jared
PDF
C++ diapositivas, introducción, operadores y funciones
DOCX
Funciones
PDF
Libro programación-en-c++
Introduccion a c++
Mynor Alexander Hernandez Canuz
Investigacion 1
Curso de C++ (2014)
Jorge salazar 4 to b xd
Jorge salazar 4 to b xd
Jorge salazar 4 to b xd
Introducción
Introducción
Tutorial C++
Lenguajec 1
Introducción al lenguaje c
A1 u1-16230227
C facil de_v2
Informe tecnico victor_uex
Instituto tecnológico particular
Tutorial jared
C++ diapositivas, introducción, operadores y funciones
Funciones
Libro programación-en-c++

Más de jlmansilla (11)

PPT
NTFSFS.ppt
PPT
maximumFlow.ppt
PPT
NTFS.ppt
PPT
LinearSortOrderSatatistics.ppt
PPT
heapsort.ppt
PPT
hashing.ppt
PPT
elementaryAlgorithms.ppt
PPT
binarySearchTree.ppt
PPT
greedy.ppt
PPT
NP_Completitud.ppt
PPTX
PERDIDA_EN_UNA_RED_DE_FIBRA_OPTICA.pptx
NTFSFS.ppt
maximumFlow.ppt
NTFS.ppt
LinearSortOrderSatatistics.ppt
heapsort.ppt
hashing.ppt
elementaryAlgorithms.ppt
binarySearchTree.ppt
greedy.ppt
NP_Completitud.ppt
PERDIDA_EN_UNA_RED_DE_FIBRA_OPTICA.pptx

Último (10)

PPTX
Implementación equipo monitor12.08.25.pptx
PDF
Clase 3 - Presentación visual (Insertando objetos visuales) POWER POINT.pdf
PPTX
Fundamentos de Python - Curso de Python dia 1
PPTX
ORIGEN DE LA IA - GRADO 1102 INTELIGENCIA
PDF
AutoCAD Herramientas para el futuro, Juan Fandiño
DOCX
trabajo programacion.docxxdxxxddxdxxdxdxxxdxxdxdxd
PPTX
sistemas de informacion.................
PPTX
Conceptos basicos de Base de Datos y sus propiedades
PPTX
Tratará sobre Grafos_y_Arboles_Presentacion.pptx
PDF
Su punto de partida en la IA: Microsoft 365 Copilot Chat
Implementación equipo monitor12.08.25.pptx
Clase 3 - Presentación visual (Insertando objetos visuales) POWER POINT.pdf
Fundamentos de Python - Curso de Python dia 1
ORIGEN DE LA IA - GRADO 1102 INTELIGENCIA
AutoCAD Herramientas para el futuro, Juan Fandiño
trabajo programacion.docxxdxxxddxdxxdxdxxxdxxdxdxd
sistemas de informacion.................
Conceptos basicos de Base de Datos y sus propiedades
Tratará sobre Grafos_y_Arboles_Presentacion.pptx
Su punto de partida en la IA: Microsoft 365 Copilot Chat

BasicC++.ppt

  • 1. ELO320 1 C++ Biblioteca Estándar de Templates Standar Template Library Agustín J. González ELO320
  • 2. ELO320 2 Características de C++ • El propósito de este material es rápidamente revisar todas características de C++ que ustedes probablemente han encontrado • Si ustedes han aprendido otro lenguaje, podrán ubicarse rápidamente • Referencia: Timothy Budd, “Data Structures in C++, using the Standard Template Library”, Addison Wesley 1998. Esta en nuestra biblioteca.
  • 3. ELO320 3 Comentarios y Constantes • Hay dos tipos de comentarios // desde doble slashes hasta el final de la línea /* Comentarios que se extienden varias líneas */ • Los comentarios deberían usarse intensamente por documentación. • Constantes: • hay varios tipos de constantes integers -1,12,-37 enteros octales 014 enteros hexadecimales 0xFF 0xC punto flotante 3.14158, 2.7e14 caracteres ‘a’ ‘n’ string “abc” • sufijos pueden ser aplicados a constantes u por unsigned l por long
  • 4. ELO320 4 Variables, Tipos, Valores y Declaraciones • Una variable es una localización con nombre que almacena un valor de cierto tipo. • Variables son creadas usando una sentencia de declaración, la cual describe también el tipo asociado. int a,b,c; // declara tres enteros • La declaración puede ser combinada con inicialización: double pi = 3.1415926; • Tipos Fundamentales de Datos • Enteros int • punto flotante: double, float • Caracter: char • Modificadores que pueden ser usados con tipos fundamentales signed,, unsigned short, long (posiblemente) mas pequeño o mas grande que estándar.
  • 5. ELO320 5 Mas tipos de Datos • Variables Booleanos (bool)son verdaderas o falsas (true/false) • Valores enumerados son definidos indicando el rango en forma explícita enum month{January, February, March, April, May, June, July,August, September, October,November, December}; months workingMonth, vacationMonth; months summerMonth = August; • Variables y Asignaciones double f, c; // Temperatura Fahrenheit y Celsius c = 43; f = (c * 9.0) / 5.0 + 32; • Operadores binarios pueden ser combinados con asignaciones i += 5; // equivale a i = i+5; • Otra anotación compacta es: i++
  • 7. ELO320 7 Stream de I/O • El operador de corrimiento izquierda y derecha tienen distinto significado cuando son usados con valores de stream. • El stream mas común es el asociado con la consola de entrada y salida. cout << "the Fahrenheit equivalent of " << c << " is " << f << "n"; cin >> c; // get a new value of c cout << "the Fahrenheit equivalent of " << c << " is " << f << "n"; • El Operador >> trabaja or efecto lateral, cambiando la expresión del lado derecho. El resultado puede ser convertido a boolean para probar si la estrada fue exitosa. int sum = 0; int value; while (cin >> value) { sum += value; } cout << "sum is " << sum << "n";
  • 8. ELO320 8 Punteros • Los punteros pueden ser usados de las siguientes formas: • Punteros pueden ser usados con subíndices (tiene sentido si apuntan a arreglos, pero esto no es chequeado) • Pueden ser des-referenciados, usando el operador * • Pueden combinar des-referencia con accesos a campos, usando operador -> • Pueden usar sumas, p+i es la dirección de p[i]
  • 9. ELO320 9 Sentencias condicionales month aMonth; ... if ((aMonth >= June) && (aMonth <= August)) isSummer = true; else // es opcional isSummer = false;
  • 10. ELO320 10 Sentencia Switch switch (aMonth) { case January: highTemp = 20; lowTemp = 0; break; case February: highTemp = 30; lowTemp = 10; break; ... case July: highTemp = 120; lowTemp = 50; break; default: highTemp = 60; lowTemp = 20; };
  • 11. ELO320 11 Bucles de repetición WHILE c = 0; while (c <= 100) { cout << "Celsius " << c << " is Fahrenheit " << ((9.0 * c) / 5.0 + 32) << "n"; c += 10; } FOR for (c = 0; c <= 100; c += 10) { cout << "Celsius " << c << " is Fahrenheit " << ((9.0 * c) / 5.0 + 32) << "n"; } for (int i = 0; i < 12; i++) { cout << "i: " << i << " i squared " << i*i << "n"; }
  • 12. ELO320 12 Arreglos • Es una colección de tamaño fijo de valores del mismo tipo. // declare an array of twelve integer values int Temperatures[12]; // now assign all values Temperatures[0] = 0; Temperatures[1] = 10; Temperatures[2] = Temperatures[1] + 15; ... • Pueden ser inicializados string MonthNames[12] = {"January", "February", "March", "April", "may", "June", "July", "August", "September", "October", "November", "December" }; • Arreglos Multidimencionales double matrix[10][20]; matrix [i][j] = matrix [i-1][j+1] + 1;
  • 13. ELO320 13 Arreglos y Punteros • Hay una relación muy cercana entre arreglos y punteros • El nombre del arreglo es tratado como un puntero. • Punteros pueden usar subíndices, como si fueran arreglos(aun si no lo son) • MonthNames+3 es legal, es la dirección de MonthNames[3]. • Arreglos como Argumentos • Cuando son usados como argumentos no necesitamos especificar el tamaño. int arraySum (int values[ ], int n) // compute sum of array values[0] .. values[n-1] { int result = 0; for (int i = 0; i < n; i++) { result += values[i] } return result; }
  • 14. ELO320 14 Estructuras • Es una colección de campos que no requieren tener el mismo tipo. struct person { string name; int age; enum {male, female} sex; }; • El acceso es via el operador . person employee; employee.name = "sam smith"; employee.age++; if (employee.sex == male) ...
  • 15. ELO320 15 Funciones • Una función encapsula un conjunto de acciones. int Fahrenheit(int cTemp) { return (cTemp * 9.0) / 5.0 + 32; } • Partes: Encabezado con tipo retornado, nombre y argumentos. Cuerpo con sentencias a ejecutar. • Valor retornado puede ser void (ningún valor) • Una función prototipo es una declaración pero sin definición. // prototype for Fahrenheit -- definition occurs later int Fahrenheit (int);
  • 16. ELO320 16 Variables Locales • Variables al interior de la función existen solo cuando la función es ejecutada, desaparecen cuando la función retorna. La excepción a esta regla son las variables estáticas. • Si suponemos que la función A llama a B y esta llama a C, podemos imaginar en el stack del proceso usuario: Variables locales de C Variables locales de B Variables locales de A • Si B fuera recursiva y llamara a si misma una vez antes de llamar a C, tenemos: Variables locales de C Variables locales de B Variables locales de B Variables locales de A
  • 17. ELO320 17 El evento Main • Todo programa debe incluir un procedimiento main, el cual es el punto de partida de la ejecución. # include <iostream> void main() { // program to write table of squares cout << "Table of Squaresn"; for (int i = 0; i < 12; i++) { cout << "i: " << i << " i squared " << i*i << "n"; } }
  • 18. ELO320 18 Archivos includes • Muchas estructuras de datos requieren que uno defina un archivo de inclusión antes que podamos usarlas. Propósito Nombre stream input/output iostream funciones matemáticas math.h números complejos complex valores booleanos bool.h algoritmos genéricos algorithm Abstracción vector vector Abstracción lista list Abstracción conjunto set Abstracción mapa map