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

Algorithmes et structures de données Discussion :

intersection segments colinéaires


Sujet :

Algorithmes et structures de données

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2011
    Messages
    176
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2011
    Messages : 176
    Points : 133
    Points
    133
    Par défaut intersection segments colinéaires
    Bonjour,

    J'aimerais savoir si c'est possible de créer un algo qui détermine les bornes d'intersection de 4 segments colinéaires.J'ai besoin que des bornes des parties des segments inclus dans le premier segment.

    Par exemple pour:s1 : [1 ,8]
    s2: [0,5]
    s3 : [2,6]
    s4 : [3, 4]
    je veux retourner :
    [1,2 ], [2,3],[3,4],[4,5],[5,6],[6,8]


    Merci de m'aider.

  2. #2
    Membre expérimenté
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Points : 1 685
    Points
    1 685
    Par défaut
    Bonjour,

    il suffit de faire une fonction élémentaire qui détermine l'intersection de deux segments [a;b] et [c;d] (a<b et c<d ou a<=b et c<=d si tu acceptes les segments dégénérés en points) puis de l'appliquer pour chaque couple de segments, puis chaque couples d'intersections, etc jusqu'à n'obtenir que des intersections vides. Pour la fonction élémentaire, c'est facile, il suffit de comparer les bornes des deux segments :
    1. on recupere min{a,c}
    (je suppose que c'est a par souci de simplicité; dans le cas contraire, il suffit d'intervertir le rôle des segments)
    2. si b<c : intersection vide
    3. si b=c : intersection = {b}={c}
    4. si b>c : intersection = [b;c]
    (sauf erreur de ma part)

  3. #3
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par Aleph69 Voir le message
    1. on recupere min{a,c}
    (je suppose que c'est a par souci de simplicité; dans le cas contraire, il suffit d'intervertir le rôle des segments)
    2. si b<c : intersection vide
    3. si b=c : intersection = {b}={c}
    4. si b>c et b<d: intersection = [c;b]
    5. si b>=d : intersection = [c;d]
    (sauf erreur de ma part, également)
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  4. #4
    Membre expérimenté
    Homme Profil pro
    Chercheur
    Inscrit en
    Mars 2010
    Messages
    1 218
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chercheur

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 218
    Points : 1 685
    Points
    1 685
    Par défaut
    Très juste! Merci pour la relecture pseudocode!

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Février 2011
    Messages
    176
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2011
    Messages : 176
    Points : 133
    Points
    133
    Par défaut
    bonjour,

    oui c'est plus juste comme ça,mais comment je peux appliquer pour chaque couple de segments la même procédure, en ayant enfin tout les intervalles.

    Cordialement

  6. #6
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par AJ_ing Voir le message
    bonjour,

    oui c'est plus juste comme ça,mais comment je peux appliquer pour chaque couple de segments la même procédure, en ayant enfin tout les intervalles.

    Cordialement
    Pour ton cas particulier donné en exemple, il suffit de séparer l'intervalle de départ [1,8] à l'aide de marqueurs. Les marqueurs étant le début/fin des autres segments.

    Bref, un simple tri sur les bornes de s2,s3,s4 et une recherche des valeurs entre 1 et 8.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Février 2011
    Messages
    176
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Février 2011
    Messages : 176
    Points : 133
    Points
    133
    Par défaut
    Bonjour,
    Mes intervalles sont bien séparés debut fin

    si j'applique cette méthode pour 2 intervalles

    la fonction doit retourner :
    si b<c return [a,b]
    si c<b <d return [a,c] [c,b]
    si b>d et c> a return [a,c] [c,d],[d,b]

    Mais si j'ajoute à chaque fois un intervalle ,comment définir les paramètres de ma fonction.

    merci

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

Discussions similaires

  1. Intersection entre segment et cercle
    Par chadliii dans le forum Mathématiques
    Réponses: 15
    Dernier message: 03/10/2019, 18h52
  2. Algo intersection de 2 segments
    Par julian_ross dans le forum Développement 2D, 3D et Jeux
    Réponses: 29
    Dernier message: 25/03/2011, 12h33
  3. Réponses: 3
    Dernier message: 22/06/2008, 16h06
  4. Intersection d'un segment et d'un AABB
    Par casafa dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 05/07/2007, 17h21

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