Ordre des lettres dans un mot, etude de l'université de cambridge

Soyez le premier à donner votre avis sur cette source.

Snippet vu 32 595 fois - Téléchargée 21 fois

Contenu du snippet

Hello!

Bon je ne sais pas si vous avez eu vent de l'étude qui a été réalisée il y a un bon moment par l'université de cambridge ? En fait elle explique que l'ordre des lettres à l'intérieur d'un mot n'a pas d'importance du moment qu'on garde en plaçe la première et la dernière lettre de ce mot. Le reste peut-être plaçé aléatoirement.

L'exemple ci-dessous donne quelquechose comme :
Bjonuor ! Ccei dnnoe un ptiet emxeple de la fnctooin que j'ai résialé ! Imnisorpsnaent n'est-ce pas ? Vorte cvreeau lit le mot cmmoe un tuot !

Pour plus d'explications un petit lien : http://www.bienlire.education.fr/05-echanges/pagefenetre/pop_reaction09.htm

Donc ça date un peu peut-être deux ans mais je voulais programmer ça pour voir voilà... Donc une petite fonction "ShakeIt".
Je laisse niveau débutant puisqu'il ne s'agit que de manipulation de chaînes basique.

Source / Exemple :


<?php
function ShakeIt($string)
{
	$sortie = "";
	$pattern = "/([\s,<>\"\.?!@;:'-]+)/";
	
	$tableau = preg_split($pattern,$string);
	preg_match_all($pattern,$string,$separateurs);
	

	foreach($tableau as $cle => $mot)
	{
		if(strlen($mot) > 3)
		{
			$cut = array_slice(split("-l-", chunk_split($mot,1, '-l-')), 0, -1);
			$mot2 = $cut[0];
			$array2 = Array();
			for($i = 1;$i < (strlen($mot) - 1); $i++)
			{
				$array2[$i] = $cut[$i];
			}
			shuffle($array2);
			for($i = 0;$i < (strlen($mot) - 1); $i++)
			{
				$mot2 .= $array2[$i];
			}
			$mot = $mot2 . $cut[strlen($mot) - 1];
		}
		
	$sortie .= $mot . $separateurs[0][$cle];
	}
	return $sortie;
}

echo ShakeIt("Bonjour ! Ceci donne un petit exemple de la fonction que j'ai réalisé ! Impressionnant n'est-ce pas ? Votre cerveau lit le mot comme un tout !");

?>

Conclusion :


Alors le fonctionnement, la chaîne $string est passée à la fonction ShakeIt, on prends le motif qui servira aux regex, qui permet de découper la chaîne. Le preg_match_all cherche à trouver les séparateurs, car si l'on utilise juste le preg_split lorsqu'on a plusieurs caractères comme ?!!! cela pose problème..

Après si le mot fais plus de trois caractères, on prends tout sauf le premier et le dernier, on mélange (shuffle) et on remet dans le mot... et on passe au mot suivant.

C'est un algorithme assez simple quand on y pense.

A voir également

Ajouter un commentaire Commentaires
Jayadeva Messages postés 67 Date d'inscription mercredi 2 juillet 2003 Statut Membre Dernière intervention 1 septembre 2008
18 mai 2007 à 02:31
Dans le même style, j'ai fait ceci : http://www.phpcs.com/codes/MELANGE-LETTRES_38876.aspx
DarkM60 Messages postés 37 Date d'inscription dimanche 15 mai 2005 Statut Membre Dernière intervention 21 septembre 2009
27 févr. 2007 à 13:39
=D En effet ^_^ Mais bon pour certains mots assez long comme "compréhensible" ça se lit pas très bien mélangé, mais c'est quand même assez surprenant en effet, et ça marche dans toutes les langues basé sur l'alphabet latin. Pour ce qui est du cyrilique je pense que cela fonctionne aussi, mais pour ce qui est du japonnais avec un alphabet syllabique je me demande si ça marcherait ou pas ^^'.
sdjenadi Messages postés 9 Date d'inscription mardi 21 décembre 2004 Statut Membre Dernière intervention 29 mars 2007
27 févr. 2007 à 08:41
Je ne savais pas qu'on lisez aussi mal, on croit tous savoir mais on n'est meme pas capable de s'apercevoir de l'ordre des mots.

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.