1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
/**
* Remplit un tableau d'objets de la même valeur
* @param objets
* Tableau à remplir
* @param depart
* Position de départ
* @param taille
* Nombre de case à remplir
* @param valeur
* Valeur de remplissage
*/
public static void remplir(Object[] objets, int depart, int taille,
Object valeur)
{
if(objets == null)
{
throw new NullPointerException("Le tableau ne doit pas être null");
}
//On verifie la taille
if(depart < 0)
{
taille += depart;
depart = 0;
}
if(depart + taille > objets.length)
{
taille = objets.length - depart;
}
if(taille < 1)
{
return;
}
//On initialise le remplissage
objets[depart] = valeur;
int l = 1;
int t = taille;
//On copie, 1, puis 2, puis 4, ... jusqu'a a atteindre 2¨n ou n tel
// maximun des n tels que 2¨n<=taille
while(t > 1)
{
System.arraycopy(objets, depart, objets, depart + l, l);
l *= 2;
t /= 2;
}
//On remplit les cases restantes (si il y en a)
int reste = taille - l;
if(reste > 0)
{
System.arraycopy(objets, depart, objets, depart + taille - reste,
reste);
}
} |
Partager