Maison développement back-end tutoriel php Comment utiliser PHP et GMP pour tester le théorème de Fermat pour les grands entiers

Comment utiliser PHP et GMP pour tester le théorème de Fermat pour les grands entiers

Jul 29, 2023 am 11:13 AM
php gmp 大整数

Comment utiliser PHP et GMP pour tester le petit théorème de Fermat pour les grands entiers

Le petit théorème de Fermat est l'un des théorèmes importants de la théorie des nombres. Il peut être utilisé pour effectuer des tests de primalité sur de grands entiers, c'est-à-dire pour déterminer si un grand entier est premier. Dans cet article, nous présenterons comment utiliser PHP et la bibliothèque d'extensions GMP pour effectuer des tests du petit théorème de Fermat pour les grands entiers.

Tout d’abord, nous devons comprendre les principes du petit théorème de Fermat. Le petit théorème de Fermat s'exprime comme suit :

Si p est un nombre premier, a est n'importe quel nombre entier et a n'est pas divisible par p, alors a^(p-1) ≡ 1 (mod p).

Selon le théorème du petit Fermat, nous pouvons effectuer le test du théorème du petit Fermat pour les grands entiers. Les étapes spécifiques sont les suivantes :

Étape 1 : Importer la bibliothèque d'extensions GMP

Étant donné que les fonctions intégrées de PHP ne peuvent pas gérer les grands entiers, nous devons importer la bibliothèque d'extensions GMP pour gérer les grands entiers. En PHP, vous pouvez importer la bibliothèque d'extension GMP via le code suivant :

if (extension_loaded('gmp')) {
    echo "GMP扩展库已加载。
";
} else {
    echo "GMP扩展库未加载。
";
    exit;
}
Copier après la connexion

Étape 2 : Implémenter la fonction de test du théorème de Fermat

Nous pouvons implémenter le test du théorème de Fermat pour les grands entiers en définissant une fonction. La fonction est définie comme suit :

function fermatTest($n, $k) {
    for ($i = 0; $i < $k; $i++) {
        $a = gmp_random_range(2, $n-1); // 随机选择一个整数a
        $result = gmp_powm($a, $n-1, $n); // 计算 a^(n-1) mod n
        if (gmp_cmp($result, 1) !== 0) { // 如果结果不等于1,则n不是素数
            return false;
        }
    }
    return true; // 如果所有测试都通过,则n可能是素数
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons la fonction gmp_random_range pour générer un entier aléatoire $a$ entre 2 et $n-1$, puis utilisons la fonction gmp_powm pour calculer $a^{n -1 } Le résultat du mod n$. Si le résultat n'est pas égal à 1, alors $n$ n'est pas un nombre premier et renvoie faux sinon, passez au test suivant ; Si tous les tests réussissent, alors $n$ est probablement premier, retourne vrai.

Étape 3 : Fonction de test

Nous pouvons écrire une fonction de test pour vérifier l'exactitude de la fonction de test du théorème de Fermat implémentée. La fonction de test est définie comme suit :

function testFermatTest($n) {
    if (fermatTest($n, 10)) { // 进行10次小费马定理测试
        echo "{$n} 可能是素数。
";
    } else {
        echo "{$n} 不是素数。
";
    }
}
Copier après la connexion

Dans le code ci-dessus, nous appelons la fonction fermatTest pour tester le théorème de Fermat 10 fois, puis générons les informations correspondantes en fonction des résultats du test.

Étape 4 : Exécuter le test

Enfin, nous pouvons appeler la fonction test pour effectuer le test du théorème de Fermat. Par exemple, nous pouvons tester un entier plus grand 1000000000000000000003 avec le code suivant :

testFermatTest(gmp_init("100000000000000000003"));
Copier après la connexion

Dans le code ci-dessus, nous utilisons la fonction gmp_init pour convertir la chaîne "1000000000000000000003" en un grand entier, puis tester le théorème de Fermat.

Grâce aux étapes ci-dessus, nous pouvons utiliser les bibliothèques d'extensions PHP et GMP pour tester le petit théorème de Fermat des grands entiers. Il s’agit d’une méthode simple mais efficace pour déterminer si un grand entier est premier.

Veuillez noter que dans les applications pratiques, le test du théorème de Fermat est souvent combiné avec d'autres méthodes de test pour améliorer la précision et la fiabilité du test.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

Journalisation CakePHP Journalisation CakePHP Sep 10, 2024 pm 05:26 PM

Se connecter à CakePHP est une tâche très simple. Il vous suffit d'utiliser une seule fonction. Vous pouvez enregistrer les erreurs, les exceptions, les activités des utilisateurs, les actions entreprises par les utilisateurs, pour tout processus en arrière-plan comme cronjob. La journalisation des données dans CakePHP est facile. La fonction log() est fournie

Comment configurer Visual Studio Code (VS Code) pour le développement PHP Comment configurer Visual Studio Code (VS Code) pour le développement PHP Dec 20, 2024 am 11:31 AM

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

See all articles