Diferència entre revisions de la pàgina «DAW 2020-2021»
Línia 10: | Línia 10: | ||
== 20210127 (1h síncrona per confinament) == | == 20210127 (1h síncrona per confinament) == | ||
[https://binefa.cat/daw2021/m03/20210127/ Alguns codis comentats avui] | [https://binefa.cat/daw2021/m03/20210127/ Alguns codis comentats avui] | ||
+ | |||
+ | === Exercicis === | ||
+ | * Feu un programa que generi set números aleatoris entre 0.00 i 10.00. S'han de posar a les set primeres posicions de vector lfVector[99]. Aprofiteu l'exercici '''m05e7_03.''' com a base per a resoldre-ho. | ||
+ | |||
+ | * El mateix que l'anterior en Python. | ||
== 20210126 (2h síncrona per confinament) == | == 20210126 (2h síncrona per confinament) == |
Revisió del 17:36, 27 gen 2021
Contingut
- 1 Horari a partir del 18 de gener
- 2 Teleconferència del curs 2020-2021
- 3 Algunes classes
- 3.1 20210127 (1h síncrona per confinament)
- 3.2 20210126 (2h síncrona per confinament)
- 3.3 20210120 (1h presencial) Robot
- 3.4 20210119 (2h síncrona)
- 3.5 20210114 (2h presencial)
- 3.6 20210111 (1h síncrona)
- 3.7 20201221 (1h síncrona)
- 3.8 20201217 (2h presencial)
- 3.9 20201214 (1h síncrona)
- 3.10 20201210 (2h presencial)
- 3.11 20201203 (2h presencial)
- 3.12 20201130 (1h síncrona)
- 3.13 20201126 (2h, presencial)
- 3.14 20201123 (1h síncrona)
- 3.15 20201120 (1h síncrona)
- 3.16 20201119 (2h presencials)
- 3.17 20201116 (1h en línia)
- 3.18 20201112 (2h presencials)
- 3.19 20201109 (1h en línia)
- 3.20 20201105 (1h)
- 3.21 20201104 (1h)
- 3.22 20201103 (2h)
- 3.23 20201029 (1h)
- 3.24 20201028 (1h)
- 3.25 20201027 (2h)
- 3.26 20201022 (1h)
- 3.27 20201021 (1h)
- 3.28 20201020 (2h)
- 3.29 20201015 (1h)
- 3.30 20201014 (1h)
- 3.31 20201013 (2h)
- 3.32 20201008 (1h)
- 3.33 20201007 (1h)
- 3.34 20201006 (2h)
- 3.35 20201001 (1h)
- 3.36 20200930 (1h)
- 3.37 20200929 (2h)
- 4 Repositori de codis fet a classe durant el curs
Horari a partir del 18 de gener
Teleconferència del curs 2020-2021
Algunes classes
20210127 (1h síncrona per confinament)
Exercicis
- Feu un programa que generi set números aleatoris entre 0.00 i 10.00. S'han de posar a les set primeres posicions de vector lfVector[99]. Aprofiteu l'exercici m05e7_03. com a base per a resoldre-ho.
- El mateix que l'anterior en Python.
20210126 (2h síncrona per confinament)
Exercicis
- Feu un programa en C i en Python, aprofitant el que avui hem vist a classe, i modifiqueu els elements del vector (llista a Python) incrementant el seu valor en un 21% (com l'IVA).
Ha de sortir així:
jordi@ecat-XPS13:~/Documents/escolaClot/curs2020-2021/m03/daw/20210126/ex$ gcc m05e7_03_mesIva.c -o m jordi@ecat-XPS13:~/Documents/escolaClot/curs2020-2021/m03/daw/20210126/ex$ ./m --------------- vVisualitzaVector: lfVector: { 2.34 4.56 -3.45 10.00 9.87 1.32 -1.27 } 1) El valor màxim del vector és 10.00 2) El valor màxim del vector és 10.00 --------------- vVisualitzaVector: lfVector: { 2.83 5.52 -4.17 12.10 11.94 1.60 -1.54 } 3) El valor màxim del vector és 12.10
Proposta de funció principal main():
int main(){ double lfVector[99] = {2.34,4.56,-3.45,10,9.87,1.32,-1.27}; // 7 elements instanciats vVisualitzaVector(lfVector); // vVisualitzaVector(&lfVector[0]); printf("1) El valor màxim del vector és %.2lf\n",lfMaximVector(lfVector,MIDA_INICIAL)); printf("2) El valor màxim del vector és %.2lf\n",lfMaximVector2(lfVector,MIDA_INICIAL)); vAfegeixIva(lfVector,MIDA_INICIAL,21.0); vVisualitzaVector(lfVector); // vVisualitzaVector(&lfVector[0]); printf("3) El valor màxim del vector és %.2lf\n",lfMaximVector(lfVector,MIDA_INICIAL)); return 0; }
I a Python:
jordi@ecat-XPS13:~/Documents/escolaClot/curs2020-2021/m03/daw/20210126/ex$ python3 m05e7_03_mesIVA.py vVector: [ 2.34 4.56 -3.45 10.00 9.87 1.32 -1.27 ] El valor màxim del vector és 10.00 vVector: [ 2.83 5.52 -4.17 12.10 11.94 1.60 -1.54 ] El valor màxim del vector és 12.10
Proposta de funció principal a Python:
lfVector = [2.34,4.56,-3.45,10,9.87,1.32,-1.27] vVisualitzaVector(lfVector) print("El valor màxim del vector és %.2lf"%lfMaximVector(lfVector)) lfVector = vAfegeixIva(lfVector,21.0) vVisualitzaVector(lfVector) print("El valor màxim del vector és %.2lf"%lfMaximVector(lfVector))
20210120 (1h presencial) Robot
Biblioteques per al robot versió 5
20210119 (2h síncrona)
Seguim amb apuntadors. Darrer dia que vam parlar d'apuntadors.
Explicació de la funció d'intercanvi (swap)
20210114 (2h presencial)
Seguim amb Arduino
Pràctiques Arduino sobre placa S4A i Snap4Arduino - 1a part
Pràctiques Arduino sobre placa S4A i Snap4Arduino - 2a part
20210111 (1h síncrona)
Comencem apuntadors.
20201221 (1h síncrona)
Dubtes de recursivitat i temes anteriors.
- Explicació de Les torres de Hanoi
Vídeo: Entendiendo la recursividad con las Torres de Hanoi
Vídeo: La terrible leyenda de las Torres de Hanói
- A partir del codi Les torres de Hanoi, feu un comptador de moviments de les torres de Hanoi. Excepcionalment podeu emprar variables globals.
- Implementeu en Python les torres de Hanoi
20201217 (2h presencial)
Alguns codis d'avui. Flanc implementat en Snap4Arduino
Porteu fet de casa l'exercici de Fibonacci traduït de Python a C.
Seguim amb Arduino
Pràctiques Arduino sobre placa S4A i Snap4Arduino - 1a part
Pràctiques Arduino sobre placa S4A i Snap4Arduino - 2a part
20201214 (1h síncrona)
La recursivitat
Exemples de recursivitat
Les torres de Hanoi (Feu un comptador de moviments)
Exercicis de recursivitat
20201210 (2h presencial)
20201203 (2h presencial)
- Feu la travessa en Python.
- Feu un menú en C que cridi els tres programes de la travessa en C i els tres programes en Python.
- Feu un menú en Python que cridi els tres programes de la travessa en C i els tres programes en Python.
20201130 (1h síncrona)
Porteu fet i acabat l'exercici 5 del mòdul 4 del d97 en C i en Python.
Porteu pensat com fer l'exercici de la travessa (quiniela).
20201126 (2h, presencial)
Heu de portar acabat en Python les solucions en C del dia anterior. Resposta proposada per n'Andrea Sánchez
Exercici 11 del mòdul 4 del d97
20201123 (1h síncrona)
20201120 (1h síncrona)
Mirar possibles solucions a l'exercici 3 del mòdul 3 (màxim comú divisor de tres nombres) i l'exercici 3 del mòdul 4 del d97 (joc d'endevinar un número entre l'1 i el 1000)
20201119 (2h presencials)
Estructura condicional switch-case (existeix en C, no en Python)
Estructura repetitiva do-while (existeix en C, no en Python)
Menú amb do-while i switch-case
Menú amb do-while i switch-case
Recursivitat i pseudoaleatorietat
Resum teòric de recursivitat i pseudoaleatorietat en C
20201116 (1h en línia)
Avui rebreu per correu electrònic la tasca a desenvolupar a l'hora de classe d'avui.
20201112 (2h presencials)
Exercici 1 de funcions
Desenvolupeu un programa en C i un altre en Python que preguntin el radi d'una roda de bicicleta i retorni la longitud del pneumàtic de la bicicleta (Pista: 2 pi R).
Exercici 2 de funcions
Desenvolupeu un programa en C i un altre en Python que preguntin els dos catets d'un triangle i calculi llur superfície.
Feu la funció lfSuperficie que sigui de tipus double en C i float en Python. El prototipus de la funció en C serà double lfSuperficie(double lfCatet1, double lfCatet2) i en Python def lfSuperficie(lfCatet1,lfCatet2)
Exercici 3 de funcions
Desenvolupeu un programa en C i un altre en Python que preguntin els dos catets d'un triangle i calculi llur hipotenusa.
En C caldrà fer servir la funció sqrt(), per tant caldrà incloure include <math.h>. Recordeu que la comppilació fent servir la biblioteca matemàtica és:
gcc -lm ex03_func.c -o e3
Un exemple d'ús de la funció sqrt() en Python
Exercici 4 de funcions
Desenvolupeu en C i en Python l'exercici 3 del mòdul 3 del d97. Recordeu que vam fer l'exercici del màxim comú divisor en C i l'exercici del màxim comú divisor en Python.
20201109 (1h en línia)
20201105 (1h)
Concepte de funció.
20201104 (1h)
Exercici 8. Algorisme 3n+1
20201103 (2h)
Exercicis d'estructures de control repetitives en Python
Per a implementar l'exercici 6 de bucles
Aquest és l'algorisme desenvolupat a classe i aquest és el codi en XML per a ser carregat per l'Snap!
Per simular un "Atura-ho Tot" en C, podeu fer servir un return 0; a la funció main()
Mireu pr02.py del Tercer dia de classe - M03 PRG 2020-2021 per saber com fer un return 0; en Python (sys.exit(0) i al principi cal afegir import sys).
20201029 (1h)
Exercicis d'estructures de control repetitives en Python
20201028 (1h)
Exercicis d'estructures de control repetitives en Python
20201027 (2h)
20201022 (1h)
1r exercici. Equació de 2n grau
20201021 (1h)
Exercicis de condicions en Python
20201020 (2h)
Exercicis de condicions en Python
20201015 (1h)
Exercicis de condicions en Python
20201014 (1h)
Exercicis de condicions en Python
20201013 (2h)
20201008 (1h)
Tercer dia de classe - M03 PRG 2020-2021
20201007 (1h)
Tercer dia de classe - M03 PRG 2020-2021
20201006 (2h)
Tercer dia de classe - M03 PRG 2020-2021
Codis del dia d'avui (comprimits els que hi eren al principi de la classe)
Tipus de dades fonamentals: Variables
20201001 (1h)
20200930 (1h)
Segon dia de classe - M03 PRG 2020-2021