banneer2

Réducteur d'URL tinad:

Collez l'adresse du site:

Rechercher sur le blog du grouik:

600px-US_36.pngJe terminais ce billet mémo d'une rewriterule en expliquant que j'indiquerai la finalité de ce que j'étais en train de coder dans un billet suivant. Ce n'est pas encore pour maintenant mais vous pouvez déjà deviner ce que je suis en train de coder pour le fun car le fait d'incrémenter un nombre en base 36 fait partie de mes besoins.

Vu que c'est je pense un bon exo d'algorythme, que c'est pour le fun (je ne ferai pas de commerce avec le projet final), ça a fait l'objet d'une petite discussion sur le forum de nolife.

<?php
 
function incrementb36($nombretoincrement)
{
    // Gnieark 2010
   // http://blog-du-grouik.tinad.fr
    // ajoute 1 à un nombre (une chaine de caracteres en fait) codé en base 36
    // la base 36 est ça:
    $b36=array( 0 => '0',    1 => '1',2 => '2',3 => '3',4 => '4',5 => '5',6 => '6',7 => '7',    8 => '8',9 => '9',10 => 'a',11 => 'b',12 => 'c',13 => 'd',14 => 'e',    15 => 'f',16 => 'g',17 => 'h',18 => 'i',    19 => 'j',20 => 'k',21 => 'l',22 => 'm',23 => 'n',24 => 'o', 25 => 'p',26 => 'q',    27 => 'r',28 => 's',29 => 't',30 => 'u',31 => 'v',32 => 'w',33 => 'x',34 => 'y',35 => 'z');
 
    $i = strlen($nombretoincrement);
 
    $x=$i;
    while (substr($nombretoincrement,($x-1),1 )=='z'){
        /*
        *Pour les permutations, découpons la chaine en trois parties
        *substr($nombretoincrement,0,$x-1) est la partie gauche
        *substr($nombretoincrement,($x-1),1 ) est le caractere en question
        *substr($nombretoincrement, $x ) est la partie de droite
        */
 
        //passer le z en question en 0:
        $nombretoincrement = substr($nombretoincrement,0,$x-1).'0'.substr($nombretoincrement, $x );
        if ($x==1)
        {
            // On est arrivé au bout de la chaine et c'est toujours un 'z'
            $nombretoincrement='1'.$nombretoincrement;
            return $nombretoincrement;
        }
        //décrementer le compteur x
        $x=$x-1;    
    }
    //faire l'addition +1 simple:
    $nombretoincrement = substr($nombretoincrement,0,$x-1).$b36[array_search(substr($nombretoincrement,($x-1),1 ),$b36)+1].substr($nombretoincrement, $x );
    return $nombretoincrement;
}
 
 
//Pour le test:
$a='0';
for ($j=0; $j<10000; $j++){
    $a=incrementb36($a);
    echo "<p>".$a."</p>";
}
?>

Ajouter un commentaire

Nom ou pseudo:
Adresse email:
Site web (facultatif):
Commentaire:

Le code HTML est affiché comme du texte et les adresses web sont automatiquement transformées.

La discussion continue ailleurs

URL de rétrolien : http://blog-du-grouik.tinad.fr/trackback/604

Fil des commentaires de ce billet

Dans la même catégorie:
dev web


Creer un tchat (chat) en AJAX php

bulle_tchat-406.jpg
Un tchat, mélangeant les techniques suivantes: javascript, AJAX, PHP, mysql et JSON, en moins de 150 lignes. Il y a quelques mois Hempstar proposait sur ce blog sa version du chat. Comme j'ai énormément progressé dans ces langages de programmation, je me demandais si je saurai le faire, en quelques

Lire la suite...



Php, générer un e-mail avec plusieurs pièces jointes.

E-mail
Voici une fonction pour envoyer un e-mail en PHP avec des pièces jointes quelque soit leur extension (ou presque). La machine qui m'a servi à faire les tests est un champs MX du domaine, et l'adresse de l'expéditeur appartient au domaine (ça aide.) Le résultat des essais: Vers une boite e-mail free

Lire la suite...


setAttribute - Patch pour internet explorer - Javascript

Internet explorer interprète mal ou pas du tout la function setAttribute. Ci dessous mon prototype à insérer en début de script pour patcher ce navigateur. Il manque surement des cas particuliers que je n'ai pas pris en compte, il suffira de rajouter des "case" dans ce prototype.

Lire la suite...


Le sélecteur de dates en javascript Version 0.3.1

calendriers.jpg
Edit du 17/11/2011, passage en version 0.3.1 pour patcher internet explorer. test ok sur IE8 et IE 9, les autres versions n'ont pas été testées. L'objet de ce codage est de permettre l'intégration simple (#feignasse) sur des sites web d'un sélecteur de date plus sexy que 3 listes déroulantes. Je me

Lire la suite...


Un filtre antispam supplémentaire pour dotclear

kill the spam
J'ai remarqué que les spammeurs qui sévissent sur mon blog, ont souvent ces deux points communs: Le nom de l'auteur contient la description du site dont il fait la promotion, souvent plus de trois mots. Il a renseigné un lien vers un site internet, évidemment. Vu que dans les commentaires légitimes,

Lire la suite...


Propulsé par Dotclear