Probléme avec remplissage tableau en java
sara
-
sara -
sara -
Bonjour,
voilà l'ennonce de mon exercice:
on se propose de gérer une liste de clients d'une entreprise
ecrire une classe java qui permet de:
remplir une tableau de clients
AFFICHER la liste des clients
Trier le liste de clients
Ajouter un client
Supprimer un client et declarer le reste à gauche
ma solution
class client:
import java.util.Scanner;
public class Client {
static String Nom;
static String Prenom;
static int age;
static Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public static void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
Client c=new Client(Nom,Prenom,age);
// for (int i = 0; i < tab.length; i++) {
tab[0]=new Client(Nom,Prenom,age);
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public static void Afficher(){
for (int i = 0; i <100; i++) {
System.out.println(tab[i].toString());
}
}
public static void trier(){
tab=new Client[tab.length];
for (int i = 0; i < tab.length; i++) {
for (int j = i+1; j < tab.length; j++) {
if((tab[i].age)>=(tab[j].age)){
Client t=tab[i];
tab[i]=tab[j];
tab[j]=t;
}
}
}
Afficher();
}
public void AjouterClient(){
}
}
class main
import java.util.Scanner;
public class Main {
public static void main(String[]args){
Scanner in=new Scanner(System.in);
int q = 0;
do{
System.out.println("********Menu***********");
System.out.println("1.Remplir un tableau de clients ");
System.out.println("2.Afficher la liste des clients ");
System.out.println("3.Trier la liste des clients ");
System.out.println("4.Ajouter un client");
System.out.println("5.Supprimer un client et décaler le reste à gauche ");
System.out.println("6.Quitter");
System.out.println("*************************");
System.out.println("entrez votre choix SVP ?");
int choix=in.nextInt();
switch(choix){
case 1:Client.remplir();break;
case 2:Client.Afficher();break;
case 3:Client.trier();
case 4:
case 5:
case 6:System.exit(0);
}
}while(q!=6);
}
}
le probléme de l execution
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
*************************
entrez votre choix SVP ?
1
Entrer le nom du client ?
slql
Entrer le prenom du client ?
sdsd
Entrer l'age du client ?
23
voulez vous continuez à saisir ?
o
Entrer le nom du client ?
zsq
Entrer le prenom du client ?
dsd
Entrer l'age du client ?
34
voulez vous continuez à saisir ?
n
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
*************************
entrez votre choix SVP ?
2
************Client************
Nom Client : zsq
Prenom Client : dsd
Age Client : 34
*******************************
Exception in thread "main" java.lang.NullPointerException
at Client.Afficher(Client.java:38)
at Main.main(Main.java:21)
voilà l'ennonce de mon exercice:
on se propose de gérer une liste de clients d'une entreprise
ecrire une classe java qui permet de:
remplir une tableau de clients
AFFICHER la liste des clients
Trier le liste de clients
Ajouter un client
Supprimer un client et declarer le reste à gauche
ma solution
class client:
import java.util.Scanner;
public class Client {
static String Nom;
static String Prenom;
static int age;
static Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public static void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
Client c=new Client(Nom,Prenom,age);
// for (int i = 0; i < tab.length; i++) {
tab[0]=new Client(Nom,Prenom,age);
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public static void Afficher(){
for (int i = 0; i <100; i++) {
System.out.println(tab[i].toString());
}
}
public static void trier(){
tab=new Client[tab.length];
for (int i = 0; i < tab.length; i++) {
for (int j = i+1; j < tab.length; j++) {
if((tab[i].age)>=(tab[j].age)){
Client t=tab[i];
tab[i]=tab[j];
tab[j]=t;
}
}
}
Afficher();
}
public void AjouterClient(){
}
}
class main
import java.util.Scanner;
public class Main {
public static void main(String[]args){
Scanner in=new Scanner(System.in);
int q = 0;
do{
System.out.println("********Menu***********");
System.out.println("1.Remplir un tableau de clients ");
System.out.println("2.Afficher la liste des clients ");
System.out.println("3.Trier la liste des clients ");
System.out.println("4.Ajouter un client");
System.out.println("5.Supprimer un client et décaler le reste à gauche ");
System.out.println("6.Quitter");
System.out.println("*************************");
System.out.println("entrez votre choix SVP ?");
int choix=in.nextInt();
switch(choix){
case 1:Client.remplir();break;
case 2:Client.Afficher();break;
case 3:Client.trier();
case 4:
case 5:
case 6:System.exit(0);
}
}while(q!=6);
}
}
le probléme de l execution
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
*************************
entrez votre choix SVP ?
1
Entrer le nom du client ?
slql
Entrer le prenom du client ?
sdsd
Entrer l'age du client ?
23
voulez vous continuez à saisir ?
o
Entrer le nom du client ?
zsq
Entrer le prenom du client ?
dsd
Entrer l'age du client ?
34
voulez vous continuez à saisir ?
n
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
*************************
entrez votre choix SVP ?
2
************Client************
Nom Client : zsq
Prenom Client : dsd
Age Client : 34
*******************************
Exception in thread "main" java.lang.NullPointerException
at Client.Afficher(Client.java:38)
at Main.main(Main.java:21)
A voir également:
- Probléme avec remplissage tableau en java
- Jeux java itel - Télécharger - Jeux vidéo
- Waptrick java football - Télécharger - Jeux vidéo
- Tableau word - Guide
- Tableau ascii - Guide
- Trier un tableau excel - Guide
25 réponses
bon il me reste le tri et la supprision
j ai un bléme dans le tri
voilà ma fonction :
public static void trier(){
for (int i = 0; i < cmpt; i++) {
if((tab[i].age)>(tab[i+1].age)){
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}}
}
j ai un bléme dans le tri
voilà ma fonction :
public static void trier(){
for (int i = 0; i < cmpt; i++) {
if((tab[i].age)>(tab[i+1].age)){
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}}
}
re
j ai preceque terminer mon exercice voilà mon code :
classe client
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
public class Client implements Comparable{
String Nom;
String Prenom;
int age;
int cmpt=0;
Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
int i=0;
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[i]=new Client(Nom,Prenom,age);
i++;
cmpt++;
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public void Afficher(){
for (int i = 0; i <cmpt; i++) {
System.out.println(tab[i].toString());
}
}
public void trier(){
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
public void AjouterClient(){
Scanner in=new Scanner(System.in);
String Nom;
String Prenom;
int age;
int i=0;
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[cmpt++]=new Client(Nom,Prenom,age);
System.out.println("votre Client a bien été ajouter Merci !!");
}
public void supprimer(){
Scanner in=new Scanner(System.in);
System.out.println("entrer l'indice de l element que vous voulez supprimer SVP ?");
int indice=in.nextInt();
for (int i = 0; i < cmpt; i++) {
if(indice==i){
tab[i]=tab[i+1];
cmpt--;
}
}
System.out.println("votre client a bien été supprimer Merci !!");
}
@Override
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
}
il me reste un probléme dans le tri j ai implementé l'interface comparable et la methode comaprto ui est en haut dans le code et j ai fait une methodede tri sa fonction et ne génére aucune exception main le probléme que cette methode de tri ne tri pas croissant ou decroissant mais il change les emplacement sans aucune notion croissant ou decroissant voilà comment il me donne l exection
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
******* ******************
entrez votre choix SVP ?
3
************Client************
Nom Client : sd
Prenom Client : sdf
Age Client : 21
*******************************
************Client************
Nom Client : sqdf
Prenom Client : sqdf
Age Client : 19
*******************************
************Client************
Nom Client : sdf
Prenom Client : sdf
Age Client : 28
*******************************
j ai preceque terminer mon exercice voilà mon code :
classe client
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
public class Client implements Comparable{
String Nom;
String Prenom;
int age;
int cmpt=0;
Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
int i=0;
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[i]=new Client(Nom,Prenom,age);
i++;
cmpt++;
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public void Afficher(){
for (int i = 0; i <cmpt; i++) {
System.out.println(tab[i].toString());
}
}
public void trier(){
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
public void AjouterClient(){
Scanner in=new Scanner(System.in);
String Nom;
String Prenom;
int age;
int i=0;
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[cmpt++]=new Client(Nom,Prenom,age);
System.out.println("votre Client a bien été ajouter Merci !!");
}
public void supprimer(){
Scanner in=new Scanner(System.in);
System.out.println("entrer l'indice de l element que vous voulez supprimer SVP ?");
int indice=in.nextInt();
for (int i = 0; i < cmpt; i++) {
if(indice==i){
tab[i]=tab[i+1];
cmpt--;
}
}
System.out.println("votre client a bien été supprimer Merci !!");
}
@Override
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
}
il me reste un probléme dans le tri j ai implementé l'interface comparable et la methode comaprto ui est en haut dans le code et j ai fait une methodede tri sa fonction et ne génére aucune exception main le probléme que cette methode de tri ne tri pas croissant ou decroissant mais il change les emplacement sans aucune notion croissant ou decroissant voilà comment il me donne l exection
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
******* ******************
entrez votre choix SVP ?
3
************Client************
Nom Client : sd
Prenom Client : sdf
Age Client : 21
*******************************
************Client************
Nom Client : sqdf
Prenom Client : sqdf
Age Client : 19
*******************************
************Client************
Nom Client : sdf
Prenom Client : sdf
Age Client : 28
*******************************
re
j ai preceque terminer mon exercice voilà mon code :
classe client
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
public class Client implements Comparable{
String Nom;
String Prenom;
int age;
int cmpt=0;
Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
int i=0;
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[i]=new Client(Nom,Prenom,age);
i++;
cmpt++;
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public void Afficher(){
for (int i = 0; i <cmpt; i++) {
System.out.println(tab[i].toString());
}
}
public void trier(){
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
public void AjouterClient(){
Scanner in=new Scanner(System.in);
String Nom;
String Prenom;
int age;
int i=0;
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[cmpt++]=new Client(Nom,Prenom,age);
System.out.println("votre Client a bien été ajouter Merci !!");
}
public void supprimer(){
Scanner in=new Scanner(System.in);
System.out.println("entrer l'indice de l element que vous voulez supprimer SVP ?");
int indice=in.nextInt();
for (int i = 0; i < cmpt; i++) {
if(indice==i){
tab[i]=tab[i+1];
cmpt--;
}
}
System.out.println("votre client a bien été supprimer Merci !!");
}
@Override
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
}
il me reste un probléme dans le tri j ai implementé l'interface comparable et la methode comaprto ui est en haut dans le code et j ai fait une methodede tri sa fonction et ne génére aucune exception main le probléme que cette methode de tri ne tri pas croissant ou decroissant mais il change les emplacement sans aucune notion croissant ou decroissant voilà comment il me donne l exection
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
******* ******************
entrez votre choix SVP ?
3
************Client************
Nom Client : sd
Prenom Client : sdf
Age Client : 21
*******************************
************Client************
Nom Client : sqdf
Prenom Client : sqdf
Age Client : 19
*******************************
************Client************
Nom Client : sdf
Prenom Client : sdf
Age Client : 28
*******************************
j ai preceque terminer mon exercice voilà mon code :
classe client
import java.util.Arrays;
import java.util.Comparator;
import java.util.Scanner;
public class Client implements Comparable{
String Nom;
String Prenom;
int age;
int cmpt=0;
Client []tab=new Client[100];
public Client(String nom, String prenom, int age) {
Nom = nom;
Prenom = prenom;
this.age = age;
}
public Client() {
}
public void remplir(){
Scanner in=new Scanner(System.in);
char car =' ';
int i=0;
do{
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[i]=new Client(Nom,Prenom,age);
i++;
cmpt++;
System.out.println("voulez vous continuez à saisir ?");
car=in.next().charAt(0);
}while(car!='n' && car!='N');
}
public String toString(){
return "************Client************\rNom Client : "+Nom+"\r Prenom Client : "+Prenom+"\r Age Client : "+age+"\r*******************************";
}
public void Afficher(){
for (int i = 0; i <cmpt; i++) {
System.out.println(tab[i].toString());
}
}
public void trier(){
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
public void AjouterClient(){
Scanner in=new Scanner(System.in);
String Nom;
String Prenom;
int age;
int i=0;
System.out.println("Entrer le nom du client ?");
Nom=in.next();
System.out.println("Entrer le prenom du client ?");
Prenom=in.next();
System.out.println("Entrer l'age du client ?");
age=in.nextInt();
Client c=new Client(Nom,Prenom,age);
tab[cmpt++]=new Client(Nom,Prenom,age);
System.out.println("votre Client a bien été ajouter Merci !!");
}
public void supprimer(){
Scanner in=new Scanner(System.in);
System.out.println("entrer l'indice de l element que vous voulez supprimer SVP ?");
int indice=in.nextInt();
for (int i = 0; i < cmpt; i++) {
if(indice==i){
tab[i]=tab[i+1];
cmpt--;
}
}
System.out.println("votre client a bien été supprimer Merci !!");
}
@Override
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
}
il me reste un probléme dans le tri j ai implementé l'interface comparable et la methode comaprto ui est en haut dans le code et j ai fait une methodede tri sa fonction et ne génére aucune exception main le probléme que cette methode de tri ne tri pas croissant ou decroissant mais il change les emplacement sans aucune notion croissant ou decroissant voilà comment il me donne l exection
********Menu***********
1.Remplir un tableau de clients
2.Afficher la liste des clients
3.Trier la liste des clients
4.Ajouter un client
5.Supprimer un client et décaler le reste à gauche
6.Quitter
******* ******************
entrez votre choix SVP ?
3
************Client************
Nom Client : sd
Prenom Client : sdf
Age Client : 21
*******************************
************Client************
Nom Client : sqdf
Prenom Client : sqdf
Age Client : 19
*******************************
************Client************
Nom Client : sdf
Prenom Client : sdf
Age Client : 28
*******************************
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
public void trier(){
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
la methode de tri et l implementation de lintreface comaparable pour utiliser la methode comparto
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
quand j' execute il ne tri pas le tableau ni par ordre croissant ni par ordre decroissant il me donne un tri en desordre
je ne sais pas c quoi le bléme pouvez m aider pour le dernier pas de mon exercice et merci d avance
for (int i = 0; i < cmpt; i++) {
for (int j =i+1; j < cmpt-1; j++) {
Client t=tab[i];
tab[i]=tab[i+1];
tab[i+1]=t;
}
}
Afficher();
}
la methode de tri et l implementation de lintreface comaparable pour utiliser la methode comparto
public int compareTo(Object o) {
Client c=(Client) o;
if(age>c.age) return 1;
else if(age<c.age) return -1;
else if(Nom.compareTo(c.Nom)>0) return 1;
else if(Nom.compareTo(Nom)<0) return -1;
else if(Prenom.compareTo(Prenom)>0) return 1;
else if(Prenom.compareTo(Prenom)<0) return -1;
return 0;
}
quand j' execute il ne tri pas le tableau ni par ordre croissant ni par ordre decroissant il me donne un tri en desordre
je ne sais pas c quoi le bléme pouvez m aider pour le dernier pas de mon exercice et merci d avance