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

Fortran Discussion :

Commande Fortran - Maximum d'occurence d'un nombre dans un vecteur


Sujet :

Fortran

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2011
    Messages : 31
    Points : 28
    Points
    28
    Par défaut Commande Fortran - Maximum d'occurence d'un nombre dans un vecteur
    Bonjour à tous,

    J'aurai besoin de votre aide sur l'existence d'une commande Fortran qui pourrait m'aider à simplifier mon problème.

    Voici le problème:

    Je dispose d'un vecteur contenant par exemple =[1,2,2,6,8,2]

    Je voudrais repérer le nombre dont le nombre d'occurrence est maximal, ici, 2.

    Existe-il une commande qui pourrait m'aider ? (même moyennant l'écriture d'une petite boucle)

    Comment gérer le cas d'égalité ?

    Cordialement,
    Nicolas823

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    USTHB
    Inscrit en
    Mai 2010
    Messages
    35
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : USTHB

    Informations forums :
    Inscription : Mai 2010
    Messages : 35
    Points : 39
    Points
    39
    Par défaut
    Bonsoir,

    essai de faire ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    A=[1,2,2,6,8,2]
    MAXVAL(A,dim=1,mask=A=2)

  3. #3
    Modérateur

    Profil pro
    Inscrit en
    Août 2006
    Messages
    974
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Août 2006
    Messages : 974
    Points : 1 346
    Points
    1 346
    Par défaut
    Est-ce que la solution suivante rencontre le critère de « commande Fortran » ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
       integer Valeur,NbrVal
       integer i,Nbr
       ...
       NbrVal = 0
       do i = 1, size(N)
          Nbr = count(N(i:) == N(i))
          if (Nbr > NbrVal) then
             NbrVal = Nbr
             Valeur = N(i)
          endif
       enddo
     
       write(*,*) Valeur, NbrVal

  4. #4
    Membre éclairé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Janvier 2013
    Messages
    388
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2013
    Messages : 388
    Points : 692
    Points
    692
    Par défaut
    Salut,
    je propose ma version :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    program main
        implicit none
        integer, allocatable :: arr(:)
        integer :: maxi
     
        arr = (/ 1, 2, 2, 6, 8, 2 /)
        print '(99i4)', arr
        maxi = val_occ_max (arr)
        print '(i4)', maxi
     
    contains
     
    function val_occ_max (v1)
        integer, intent(in) :: v1(:)
        integer, allocatable :: v2(:)
        integer :: value, occur, val_occ_max, nb_occ_max
     
        allocate(v2(size(v1)))
        v2(:) = v1(:)
        val_occ_max = 0
        nb_occ_max = 0
        do
            if (size(v2) <= 0) exit
            value = maxval(v2)
            occur = count(v2 == value)
            print '(3i4)', value, occur, size(v2)
            if (occur > nb_occ_max) then
                val_occ_max = value
                nb_occ_max = occur
            endif
            v2 = pack(v1, v1 < value)
        enddo
        deallocate(v2)
     
    end function val_occ_max
     
    end program main

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2011
    Messages
    31
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2011
    Messages : 31
    Points : 28
    Points
    28
    Par défaut
    Merci à tous.

    Effectivement, je me suis débrouillé avec maxval et suis arrivé à mes fins.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Débutant] nombre d'occurence d'une valeur dans un vecteur
    Par kevin07 dans le forum MATLAB
    Réponses: 5
    Dernier message: 08/10/2010, 16h15
  2. Permutation des nombres dans un vecteur
    Par Cluster dans le forum Pascal
    Réponses: 6
    Dernier message: 01/03/2009, 19h14
  3. Réponses: 1
    Dernier message: 03/08/2008, 14h21
  4. Recherche d ' un nombre dans un vecteur
    Par racoboss dans le forum Langage
    Réponses: 3
    Dernier message: 11/01/2008, 19h43
  5. localisation d'un nombre dans un vecteur
    Par jmbonnaz dans le forum MATLAB
    Réponses: 5
    Dernier message: 18/04/2007, 09h29

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