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

Soyez le premier à donner votre avis sur cette source.

Snippet vu 31 104 fois - Téléchargée 19 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

Messages postés
67
Date d'inscription
mercredi 2 juillet 2003
Statut
Membre
Dernière intervention
1 septembre 2008

Dans le même style, j'ai fait ceci : http://www.phpcs.com/codes/MELANGE-LETTRES_38876.aspx
Messages postés
37
Date d'inscription
dimanche 15 mai 2005
Statut
Membre
Dernière intervention
21 septembre 2009

=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 ^^'.
Messages postés
9
Date d'inscription
mardi 21 décembre 2004
Statut
Membre
Dernière intervention
29 mars 2007

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.