begin process at 2012 05 29 12:07:36
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Archive C/C++

 > 

Archives

 > 

Au secours

 > 

Garder la partie entière d'un float ???


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Garder la partie entière d'un float ???

mercredi 9 novembre 2005 à 14:47:13 | Garder la partie entière d'un float ???

tintin72

Bonjour,

J'aimerai savoir comment faire pour ne garder que la partie entière d'un float.
J'ai essayé de "caster" le float en int, et j'ai aussi essayé la fonction floor().
Dans l'ensemble ça marche, mais le problème c'est que lorsque la partie décimale du float est égale à zéro
ex: 94.0000000
ça m'arrondi le nombre à 93 au lieu de le laisser à 94.

Est ce que quelqu'un aurait une solution.

Merci

Tintin 72

mercredi 9 novembre 2005 à 14:55:46 | Re : Garder la partie entière d'un float ???

DeAtHCrAsH

Ce bout de code marche très bien avec un cast pour éviter les warnings:

int main(int argc, char *argv[])

{

float fNb;

int iNb;

fNb = 94.000000;

iNb = (int)fNb;

cout << iNb << endl;

return 0;

}



Shell
mercredi 9 novembre 2005 à 16:14:40 | Re : Garder la partie entière d'un float ???

cosmobob

salut,
si ca marche pas, c'est parce que qd tu ecris : float f = 94.0, suivant ta machine, il se peut qu'en fait f vaile 93.999998 ou qqc du genre. c'est parce que 94.0 n'a pas d'écriture finie en base 2.

a+

mercredi 9 novembre 2005 à 17:58:54 | Re : Garder la partie entière d'un float ???

tintin72

Houlaa   ça m'arrange po du tout !

En fait, j'ai une fonction qui retourne des résultats de divisions en float.
Ce que je voudrais faire c'est récupérer la partie entière pour ensuite l'utiliser en tant que int.
Mais d'aprés ce que tu dis, même si  le résultat d'une division tombe juste par (ex: 94) j'aurai en fait 93.9999998 ??????

Y aurait pas un moyen de résoudre ce genre de pb ?

Tintin 72
jeudi 10 novembre 2005 à 00:19:13 | Re : Garder la partie entière d'un float ???

cosmobob

tu peux pas demander une précision infinie a une machine sur laquelle les reels sont codés que sur une taille finie. si tes algorithmes sont pas stables numériquement, et que tu travailles avec des nombres reels, alors ton probleme est mal posé.
si t'es sur que ta division tombe juste, travaille depuis le debut avec des entiers voila tout...
sinon change tes egalités entre float par une difference qui doit etre petite ...

a+

jeudi 10 novembre 2005 à 00:21:37 | Re : Garder la partie entière d'un float ???

cosmobob

sinon utilises ceil (entier le plus proche) plutot que floor ou le cast en int (partie entiere).
au moins si ca tombe juste a coté a cause des arrondis sur les reels, tu vas re trouver le bon entier

a+



Cette discussion est classée dans : garder, entière, essayé, partie, float


Répondre à ce message

Sujets en rapport avec ce message

Partie entière d'un nombre [ par Sniper_Vgaerr ] Bonjour,J'aurai voulu un petit renseignement, j'aurai voulu savoir comment faire pour savoir si un chiffre est entier ou pas ? J'ai une procedure dans (win32) scrollbar sur partie de l'ecran [ par mogwai93 ] bonjour, j'aimerais avoir un scrollbar que sur une zone de l'ecran exemple :   http://img154.imageshack.us/img154/221/image6gr.gif pour le moment, j Garder des données d'une interface a une autre interface [ par Bason_sensei ] Bonjour, j'ai un petit pbl d'interface : //classe1 lesUsers[0].affiche()j'ai les donné //classe2 classe1().lesUsers[0].affiche()j'ai pus les données rand [ par imanedaoudi ] Bonjour, je veux generer des float avec 3 chiffre apres la firgule et les ecrire dans un fichier txt j'ai utilisé la fonction suivante: void vecteur:: error: expected unqualified-id before string constant [ par stegano ] Bonjour tout le monde, voila j'apprend le c++. voici ce que j'essaye de faire *** Fichier main.cpp *** #include "point1.h" #include using namespace Errreur [ par RM50Man ] Mon code ne marche pas: Le compilateur devcpp me met build error 1 #include /* contient déjà et */ #include #include #include void reset VOIP [ par norton ] Bonjour,je m'interèsse au VOIP, j'aimerai bien essayer de développer un soft pour faire une conversation vocale mais je sais pas trop comment faire, j Probleme de Updata(FALSE) en visual c++ [ par Djule01 ] Bonjour J'ai un petit probleme en visual C++  Je voudrais qu' en cliquant sur un bouton se situant dans une boite de dialogue, une instruction (Par WxWidgets How to install? [ par alex_kirchen ] Hello!Ca va faire une semaine que j'essaie d'installer WxWidgets d'une manière ou d'une autre sur mon ordi.J'ai déjà posté un message, mais comment lire des float à partir d'un fichier texte ? [ par zaim khelifi ] Hi,qui peut me faire un programme simple pour lire des float à partir d'un fichier texte ?le fichier à le format suivant (exemple):1 0.00000 0.00000 0


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,092 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales