Accueil > > > RESISTANCE EQUIVALANTE DE RESISTANCES EN SERIE OU PARALLELE
RESISTANCE EQUIVALANTE DE RESISTANCES EN SERIE OU PARALLELE
Information sur la source
Description
Alors voila, c'est mon tout premier code, il permet de choisir le nombre de resistances puis de calculer la resistance equivalante de toutes ce resistances qu'elles soient en serie ou en parallele dites moi ce que vous en pensez
Source
- #include <stdio.h>
- #include <stdlib.h>
- #include <math.h> //Permet de recuperer la partie decimale de la resistance equivalante
- #include <string.h> // permet de convertir une varriable numerique en chaine de caractere
-
-
-
-
- void main ()
- {
-
- while (1) // boucle infinie pour que le programme ne se quitte pas tout seul
- {
-
- // on declare les varriables
-
- char ctype = 0 ; // Caractere taper par l'utilisateur pour l'appel des fonctions
- char caff_resultat [20] ; // Chaine contenant le resultat dont les zeros inutiles de la partie decimale ont été tronqués
-
- int inbresistor = 0 ; // Nombre de resistances
- int ilong ; // longueur de la chaine "caff_resultat" pour pouvoir tronquer les zeros superflux
-
- double Req = 0 ; // Resistance equivalante
- double dAd = 0 ; // inverse de la resistance euivalante
- double dec = 0 ; // parite decimale de la resistance equivalante
- double ent = 0 ; // partie entiere de la resistance equivalante
-
- // on declare les tableau pour allocation dynamique
-
- double *resistor ; // tableau contenant les valeur des resistances
- double *G ; // tableau contenant les inverses des resistances
-
-
- // On boucle pour que l'utilisateur ne puisse appuyer que sur les touches predifinies
-
- while ( ctype != '1' ) // on sort de la boucle si l'utilisateur appui sur "1"
- {
- if ( ctype == '2' )
- { break ; } // on sort de la boucle si l'utilisateur appui sur "2"
- if ( ctype == 'Q' )
- { exit (-1) ; } // on quitte le programme si l'utilisateur appui sur "Q"
-
- system ("cls") ;
-
- printf ( "1 : Resistances en serie.\n\n2 : resistances en parallele. \n\nQ : quiter le programme. " );
-
- scanf( "%s", &ctype ) ;
- }
-
- if ( ctype == '1' )
-
- {
- system ("cls") ;
- printf ( "vous avez selectionner des resistances en serie.\n\n" ) ;
- printf ( "combien de resistances avez vous?\n\n " ) ;
-
- scanf ( "%d", &inbresistor ) ;
- }
-
- else if ( ctype == '2' )
-
- {
- system ("cls") ;
- printf ( "vous avez selectionner des resistances en parallele.\n\n" ) ;
- printf ( "combien de resistances avez vous?\n\n " ) ;
-
- scanf ( "%d", &inbresistor ) ;
- }
-
- if ( inbresistor == 1 ) // avec cette condition on evite les aberances comme demander la resistance equivalante a une seul resistance ;)
- {
- system ("cls") ;
-
- printf ( "vous avez demander un calcul pour une seule resistance\n\n.....vous etes un idiot...\n\n" ) ;
-
- system ("pause") ;
-
- exit (-1) ;
- }
-
- //////////////////////////////////////////////////////////////////////
- // On initialise les tableau en leur alouant de la memoire //
- // la memoire allouer depend directement de la taille du tableau //
- // par exemple la valeur d'une resistance est sur un type double //
- // donc on allou comme memoire la taille d'un double multiplié //
- // par le nombre de valeur a entrer dans le tableau //
- //////////////////////////////////////////////////////////////////////
-
- resistor = ( double*) malloc (sizeof (double) * inbresistor ) ;
- G = (double*) malloc (sizeof (double) * inbresistor ) ;
-
-
- // on recupere dans cette boucle la valeur de chaque resistance
-
- for ( int i = 1; i <= inbresistor; i++ )
-
- {
- printf ( "veuillez entrer la valeur de la resistance R%d. \n\n", i ) ;
-
- scanf ( "%lf", &resistor [i - 1] ) ;
-
- if ( resistor [i - 1] <= 0 ) // cette condition permet de se proteger d'une division par zero au moment du calcule la la resistance equivalante
- {
- system ("cls") ;
-
- printf ( "vous avez choisi une resistance de nulle ou negative\n\n...vous etes un idiot...\n\n" ) ;
-
- system ("pause") ;
-
- exit (-1) ;
- }
- }
-
- // On calcule la resistante equivalante pour des resistances en serie
-
- if ( ctype == '1' )
- {
- for ( int i = 1; i <= inbresistor; i++ )
- {
- Req = Req + resistor [i - 1] ; // n'oublier pas le -1 car le tableau à un index 0,
- // le numero de resistance 1 corespond a l'index 0 du tableau
- // donc le numero n corespond a l'index "n-1" ;)
-
- }
-
- }
-
- // On calcule la resistante equivalante pour des resistances en parallele
-
- else if ( ctype == '2' )
- {
- for ( int i = 1; i <= inbresistor; i++ )
- {
- G [i - 1] = 1/resistor [i - 1] ;
-
- dAd = dAd + G [i - 1] ;
-
- }
-
- Req = 1/dAd ;
- }
-
- dec = modf ( Req, &ent ) ; // on recupere la partie decimale de la resistance equivalante
-
- if ( dec == 0 ) // si elle est nulle alors on affiche que la partie entiere
- {
- system ("cls") ;
-
- printf ("\n\nLa resistance equivalante est Req = %.0lf .\n\n", Req ); // ex : si Req = 22 on lira 22 et non pas 22.000000 ;)
- }
- else
- {
-
- sprintf (caff_resultat, "%lf", Req ) ; // ici on converti la valeur Req en chaine de caractere caff_resultat
-
- ilong = strlen (caff_resultat) ; //ilong recupere le nombre de caractere present dans la chaine
-
- for (int j = ilong - 1; j > 0; j--) // on tronque les zero inutile de la partie decimale
- {
- if ( caff_resultat [j] == '0' )
- {
- caff_resultat [j] = '\0';
- }
-
- else
- {
- break ;
- }
- }
- system ("cls") ;
-
- printf ("\n\nLa resistance equivalante est Req = %s .\n\n", caff_resultat ) ; // donc si la Req = 22.15 en affichan la chaine tronquée on lira 22.15 et non pas 22.150000
-
- }
-
- // ne pas oublier de liberer la memoire allouée
-
- free (resistor) ;
- free (G) ;
-
- system ("pause") ; // petite pause avant le rebouclage au debut du code
-
- }
-
-
- }
#include <stdio.h>
#include <stdlib.h>
#include <math.h> //Permet de recuperer la partie decimale de la resistance equivalante
#include <string.h> // permet de convertir une varriable numerique en chaine de caractere
void main ()
{
while (1) // boucle infinie pour que le programme ne se quitte pas tout seul
{
// on declare les varriables
char ctype = 0 ; // Caractere taper par l'utilisateur pour l'appel des fonctions
char caff_resultat [20] ; // Chaine contenant le resultat dont les zeros inutiles de la partie decimale ont été tronqués
int inbresistor = 0 ; // Nombre de resistances
int ilong ; // longueur de la chaine "caff_resultat" pour pouvoir tronquer les zeros superflux
double Req = 0 ; // Resistance equivalante
double dAd = 0 ; // inverse de la resistance euivalante
double dec = 0 ; // parite decimale de la resistance equivalante
double ent = 0 ; // partie entiere de la resistance equivalante
// on declare les tableau pour allocation dynamique
double *resistor ; // tableau contenant les valeur des resistances
double *G ; // tableau contenant les inverses des resistances
// On boucle pour que l'utilisateur ne puisse appuyer que sur les touches predifinies
while ( ctype != '1' ) // on sort de la boucle si l'utilisateur appui sur "1"
{
if ( ctype == '2' )
{ break ; } // on sort de la boucle si l'utilisateur appui sur "2"
if ( ctype == 'Q' )
{ exit (-1) ; } // on quitte le programme si l'utilisateur appui sur "Q"
system ("cls") ;
printf ( "1 : Resistances en serie.\n\n2 : resistances en parallele. \n\nQ : quiter le programme. " );
scanf( "%s", &ctype ) ;
}
if ( ctype == '1' )
{
system ("cls") ;
printf ( "vous avez selectionner des resistances en serie.\n\n" ) ;
printf ( "combien de resistances avez vous?\n\n " ) ;
scanf ( "%d", &inbresistor ) ;
}
else if ( ctype == '2' )
{
system ("cls") ;
printf ( "vous avez selectionner des resistances en parallele.\n\n" ) ;
printf ( "combien de resistances avez vous?\n\n " ) ;
scanf ( "%d", &inbresistor ) ;
}
if ( inbresistor == 1 ) // avec cette condition on evite les aberances comme demander la resistance equivalante a une seul resistance ;)
{
system ("cls") ;
printf ( "vous avez demander un calcul pour une seule resistance\n\n.....vous etes un idiot...\n\n" ) ;
system ("pause") ;
exit (-1) ;
}
//////////////////////////////////////////////////////////////////////
// On initialise les tableau en leur alouant de la memoire //
// la memoire allouer depend directement de la taille du tableau //
// par exemple la valeur d'une resistance est sur un type double //
// donc on allou comme memoire la taille d'un double multiplié //
// par le nombre de valeur a entrer dans le tableau //
//////////////////////////////////////////////////////////////////////
resistor = ( double*) malloc (sizeof (double) * inbresistor ) ;
G = (double*) malloc (sizeof (double) * inbresistor ) ;
// on recupere dans cette boucle la valeur de chaque resistance
for ( int i = 1; i <= inbresistor; i++ )
{
printf ( "veuillez entrer la valeur de la resistance R%d. \n\n", i ) ;
scanf ( "%lf", &resistor [i - 1] ) ;
if ( resistor [i - 1] <= 0 ) // cette condition permet de se proteger d'une division par zero au moment du calcule la la resistance equivalante
{
system ("cls") ;
printf ( "vous avez choisi une resistance de nulle ou negative\n\n...vous etes un idiot...\n\n" ) ;
system ("pause") ;
exit (-1) ;
}
}
// On calcule la resistante equivalante pour des resistances en serie
if ( ctype == '1' )
{
for ( int i = 1; i <= inbresistor; i++ )
{
Req = Req + resistor [i - 1] ; // n'oublier pas le -1 car le tableau à un index 0,
// le numero de resistance 1 corespond a l'index 0 du tableau
// donc le numero n corespond a l'index "n-1" ;)
}
}
// On calcule la resistante equivalante pour des resistances en parallele
else if ( ctype == '2' )
{
for ( int i = 1; i <= inbresistor; i++ )
{
G [i - 1] = 1/resistor [i - 1] ;
dAd = dAd + G [i - 1] ;
}
Req = 1/dAd ;
}
dec = modf ( Req, &ent ) ; // on recupere la partie decimale de la resistance equivalante
if ( dec == 0 ) // si elle est nulle alors on affiche que la partie entiere
{
system ("cls") ;
printf ("\n\nLa resistance equivalante est Req = %.0lf .\n\n", Req ); // ex : si Req = 22 on lira 22 et non pas 22.000000 ;)
}
else
{
sprintf (caff_resultat, "%lf", Req ) ; // ici on converti la valeur Req en chaine de caractere caff_resultat
ilong = strlen (caff_resultat) ; //ilong recupere le nombre de caractere present dans la chaine
for (int j = ilong - 1; j > 0; j--) // on tronque les zero inutile de la partie decimale
{
if ( caff_resultat [j] == '0' )
{
caff_resultat [j] = '\0';
}
else
{
break ;
}
}
system ("cls") ;
printf ("\n\nLa resistance equivalante est Req = %s .\n\n", caff_resultat ) ; // donc si la Req = 22.15 en affichan la chaine tronquée on lira 22.15 et non pas 22.150000
}
// ne pas oublier de liberer la memoire allouée
free (resistor) ;
free (G) ;
system ("pause") ; // petite pause avant le rebouclage au debut du code
}
}
Conclusion
j'attends vos commentaires ou critiques
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Allocation memoire [ par youga ]
Bonjour je fais un programme de filtrage d'images en C sur VisualDSP++. J'ai donc une matrice d'entrée et je dois absolument pouvoir determiner l'add
projet allocation efficace de memoire [ par gildaso ]
Salut à tous! Alors voila je suis en licence d'informatique et j'ai un projet à rendre pour la mi-mai.Ce projet consiste à i
allocation efficace de memoire [ par gildaso ]
Salut à tous! Alors voila je suis en licence d'informatique et j'ai un projet à rendre pour la mi-mai.Ce projet consiste à i
[ c ] Allocation memoire [ par Titi035 ]
Bonjour, Je recherche quel serait le meilleur allocateur mémoire pour mon appli embarquée. J'ai 10 Mo de RAM + flash à gér
fonction malloc [ par Trollien ]
Salut,j'aurai une question concernant le fonctionnement de l'allocation de memoire en c.Si j'alloue de la memoire avec la fonction malloc(...), est ce
allocation memoire qui echoue, mais pourquoi?? [ par Seomaz ]
Bonjour,je pense que le titre est assez explicite...mais je détaille quand même:lors d'une allocation dynamique (avec l'operateur new), je me retrouve
allocation de memoire [ par tcok ]
salut a tousje voudrais juste savoir quelle est la difference entre LocalAlloc et GlobalAlloc car je dois resever un gros espace en memoire et je me d
COMPLEXITE, TEMPS ET MEMOIRE utilise par un ALGORITHME [ par RaZoR ]
J'ai découvert, il n'y a pas longtemps de cela, un concours de programmation réservé aux jeunes français de moins de 18 ans et créer par des étudiants
Fuite memoire + Debug [ par Manson ]
Bonjour a tous.Voila j'ai un gros probleme, voila un bout de code qui me met la tete a l'envers, et j'aimerai que l'on m'explique ce qui se passe :#pr
Afficher charge CPU disponibilite memoire et disque [ par kobee12 ]
J'aimerais faire un prog qui me permette d'afficher en temps reel la charge CPU la disponibilite memoire et disque de mon pc, et out ca en C.Si quelqu
|
Derniers Blogs
UNE JOLIE-HORLOGE ET PAS QU'UN PEU !UNE JOLIE-HORLOGE ET PAS QU'UN PEU ! par neodante
Pour les possesseurs d'iPhone, ça y est Bijin Tokei - qui se traduit littéralement en Français par " Jolie Horloge " - est arrivé et GRATUITEMENT s'il vous plaît ! Après la version Tokyo, Hokkaido, night club, racing, Gal, "pour les mademoiselles'", . voi...
Cliquez pour lire la suite de l'article par neodante TECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICESTECHDAYS PARIS 2010 : CONNECTEZ VOS DONNéES à SHAREPOINT 2010 AVEC LES BUSINESS CONNECTIVITY SERVICES par ROMELARD Fabrice
Animé par: Gaetan Bouveret et Julien Chomarat Business Connectivity Services (BCS) est dans SharePoint 2010 la version 2 de Business Data Catalog (BDC dans SharePoint 2007). Il s'agit de la solution permettant de visualiser des données provenan...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice [DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE[DIVERS] SUIVRE VOS SéRIES PRéFéRéS SUR LA TOILE par orion
Comme de nombreux geek, je suis un grand amateur de série TV et je rate régulièrement des épisodes de mes séries préférés. Une solution s'offre à vous avec ce merveilleux site : Tv Gorge - www.tvgorge.com Moteur de recherche à l'appui, vous pouvez ...
Cliquez pour lire la suite de l'article par orion TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010TECHDAYS PARIS 2010 : LA BI DANS SHAREPOINT 2010 par ROMELARD Fabrice
Animé par: Vincent Bellet et Baptiste Giraudier La BI dans SharePoint 2010, Les nouveaux services d'application dans SP2010 et SQL Server Reporting services 2008 R2. La BI dans SharePoint est généralisée pour tous afin de permettre à tous les coll...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Forum
RE : WIN APIRE : WIN API par racpp
Cliquez pour lire la suite par racpp WIN APIWIN API par omarino_007
Cliquez pour lire la suite par omarino_007
Logiciels
DB-MAIN (9.1.0)DB-MAIN (9.1.0)DB-MAIN is a data-modeling and data-architecture tool. It is designed to help developers and anal... Cliquez pour télécharger DB-MAIN Xilisoft DPG Convertisseur (5.1.37.0120)XILISOFT DPG CONVERTISSEUR (5.1.37.0120)Xilisoft DPG Convertisseur offre aux fans de Nintendo DS une bonne solution leur permettant de dé... Cliquez pour télécharger Xilisoft DPG Convertisseur GraphicsGale (2.01.01)GRAPHICSGALE (2.01.01)GraphicsGale est un logiciel de PixelArt avec de nombreuse fonctionnalités permettant de réalisé ... Cliquez pour télécharger GraphicsGale Architecte 3D (Platinum 2010)ARCHITECTE 3D (PLATINUM 2010)Architecte 3D Platinium vous permet de concevoir facilement les plans votre future maison, de l'é... Cliquez pour télécharger Architecte 3D TeamViewer 5 (TeamViewer 5)TEAMVIEWER 5 (TEAMVIEWER 5)Dépanner un ami,expliquer une manipulation devient un jeu d'enfant.
Prise en main d'un autre ord... Cliquez pour télécharger TeamViewer 5
|