IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

La puissance égale ou proche


Sujet :

Java

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur Java
    Inscrit en
    Juin 2013
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2013
    Messages : 54
    Points : 31
    Points
    31
    Par défaut La puissance égale ou proche
    Bonsoir,

    je veux créer un petit programme en java qui permet de saisir un entier n et qui permet de déterminer l'entier k tels que 2^k<=n,voila ce que j'ai écris:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     System.out.println("Enter n:");
       		BufferedReader br1 = new BufferedReader(new InputStreamReader(System.in));
               String line1 = br1.readLine();
               int n = Integer.parseInt(line1);
               int k=0;
               int r=n%2^k;
               n=2^k+r;
               System.out.println(""+k);
    ça ne me donne pas ce que je cherche par exemple quand je tape 7 au lieu qu'il me donne 2 il me donne toujours 0
    qu'est-ce-que je peux faire donc?

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    J'ai du mal à comprendre en quoi cet algorithme est censé répondre à la question

    k, à aucune moment, n'est calculé. La seule valeur attribuée à k est

    k=0.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Développeur Java
    Inscrit en
    Juin 2013
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2013
    Messages : 54
    Points : 31
    Points
    31
    Par défaut
    mon but de cet algorithme est de trouver k qui vérifie 2^k(2 à la puissance k)<=n,où n est un entier qu'on a entré
    par exemple pour n=8 ici k=3(2^3=8) et le reste est 0,si n=7 k=2 et le reste est 3
    tu as compris?
    Je veux savoir est-ce-qu'il y'a une façon en java de calculer k?
    j'ai initialisé k à 0 car le compilateur m'oblige de faire ça.

  4. #4
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    quelque soit le langage, quand on veut encoder un algorithme, on écrit d'abord l'algo en langage naturel, puis en pseudo code (on peut écrire le pseudo code directement si on suffisamment à l'aise avec l'algo), puis on traduit le pseudo code dans le langage voulu (on peut coder directement un algo quand on est suffisamment à l'aise avec l'algo et avec le langage). L'algo peut être pensé en fonction du langage éventuellement, lorsqu'on connait bien le langage, genre pour optimiser par exemple, mais il semble que tu n'en sois pas à ce niveau.

    Donc d'abord établis comment tu calculerais k si tu avais à le faire uniquement avec un papier et un crayon :
    - genre incrémente k jusqu'à ce que tu atteignes n (donc une boucle)
    - ou se baser sur le fait qu'un nombre du type 2^k+r peut se décomposer en 2^k donc un nombre binaire avec un seul digit à 1 et r, un nombre forcément inférieur à 2^k

    Quand tu auras déterminé comment calculer k sur papier, l'encodage en java viendra naturellement...
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  5. #5
    Membre expérimenté Avatar de Nico02
    Homme Profil pro
    Developpeur Java/JEE
    Inscrit en
    Février 2011
    Messages
    728
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Developpeur Java/JEE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 728
    Points : 1 622
    Points
    1 622
    Par défaut
    Salut,
    Tu devrais regarder ce topic, je pense que tu pourras t'en aider pour construire ton algo

    Cdt.

  6. #6
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Perso j'ai tendance à utiliser directement la fonction logarithme

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    k = Math.floor(Math.log(n)/Math.log(2))
    Bien sur, en puissance de deux, on peux jouer sur l'aspect binaire des nombres pour avoir plus facile:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    k = 31 - Integer.numberOfLeadingZeros(n)

Discussions similaires

  1. Est ce que la fin du C est proche ou pas ?
    Par Nasky dans le forum C
    Réponses: 116
    Dernier message: 13/12/2016, 15h23
  2. Puissance entière de 2 la plus proche
    Par Razgriz dans le forum Mathématiques
    Réponses: 16
    Dernier message: 30/10/2007, 12h17
  3. [LG]fonction puissance en pascal
    Par le 27 dans le forum Langage
    Réponses: 8
    Dernier message: 13/12/2003, 23h21
  4. x² et puissance de x par récurrence
    Par olivieram dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 15/12/2002, 23h59
  5. Besoin d'aide pour l'I.A. d'un puissance 4
    Par Anonymous dans le forum C
    Réponses: 2
    Dernier message: 25/04/2002, 17h05

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo