[LT HĐT với Java] Bài tập lớp trừu tượng, phương thức trừu tượng trong Java [311016]

Bài tập lớp trừu tượng, phương thức trừu tượng trong Java:

 Xây dựng project tính lương cho nhân viên công ty ABC. Trong công ty có các loại đối tượng cần tính lương sau:
 1. Lập trình viên:
  Lương = Lương cơ bản + Thưởng tháng
   ( trong đó, thưởng tháng = 1,5 lương cơ bản nếu số ngày công >= 23; ngược lại thưởng tháng = 1 lương cơ bản).
 2. Nhân viên văn phòng:
  Lương = Hệ số lương * Lương cơ bản
  ( trong đó, hệ số lương khởi điểm =2.34, cứ sau 3 năm hệ số lương tăng thêm 0.33)
 3. Cán bộ quản lý:
  Lương = Hệ số lương * Lương cơ bản + Phụ cấp chức vụ
  ( trong đó, hệ số lương tính tương tự NV văn phòng; Phụ cấp chức vụ = 2,000,000đ nếu chức vụ là trưởng phòng, 1,500,000đ nếu chức vụ là phò phòng)
*Yêu cầu:
 + Sử dụng mô hình lớp kế thừa
 + Sử dụng phương thức khởi tạo trong mỗi lớp
 + Nhập thông tin, và in thông tin nhân viên.
--------
[Sử dụng Netbean]
Xây dựng project như hình vẽ


Trong đó, lớp NV là lớp trừu tượng; lớp LapTrinhVien kế thừa lớp NV; lớp NVVP kế thừa lớp NV; lớp CanBoQL kế thừa lớp NVVP.

//
/*
  lớp trừu tượng (abstract class) - lớp NV
 */


package lthdt_bai2_311016;
import java.util.Scanner;
/**
 *
 * @author tailieucntt.org
 */
public abstract class NV {
    String hoTen, loaiNV;
    final float LCB=1050000, HeSoLuongKhoiDiem=2.34f;
 
    // Khởi tạo (constructor)
    public NV(String hoTen, String loaiNV){
        this.hoTen=hoTen;
        this.loaiNV=loaiNV;
    }
 
    // Nhập thông tin
    void NhapTT(){
        Scanner inp=new Scanner(System.in);
        System.out.print("\n + Nhap thong tin nhan vien: ");
        System.out.print("\n - Ho va ten: ");
        hoTen=inp.nextLine();
     
    }
    // Phương thức trừu tượng, tính lương
    abstract float TinhLuong();
    // In thong tin
    void InTT(){
       System.out.print("\n + In thong tin NV: ");
       System.out.print("\n - Ho va ten: "+ hoTen);
       System.out.print("\n - Loai nhan vien: "+loaiNV);
       System.out.print("\n - Luong thang: "+TinhLuong());
    }
}
//

/*
 Lớp LapTrinhVien
 */

package lthdt_bai2_311016;
import java.util.Scanner;
/**
 *
 * @author tailieucntt.org
 */
class LapTrinhVien extends NV{
    int soNgayLV;
    // phương thức khởi tạo
    public LapTrinhVien(String hoTen, String loaiNV,int soNgayLV){
        super(hoTen,loaiNV);
        this.soNgayLV=soNgayLV;
    }
    // Nhâp thông tin
    void NhapTT(){
        super.NhapTT();
        loaiNV="Lap trinh vien";
        Scanner inp=new Scanner(System.in);
        System.out.print("\n - So ngay cong: ");
        soNgayLV=inp.nextInt();
    }
    // Tính lương
    float TinhLuong(){
        float thuongThang=0;
        if(soNgayLV>=23) thuongThang=1.5f*LCB;
        else thuongThang=LCB;
        return LCB+thuongThang;
     
    }
}

//
/*
 Lớp Nhân viên VP
 */

package lthdt_bai2_311016;
import java.util.Scanner;
/**
 *
 * @author tailieucntt.org
 */
public class NVVP extends NV{
    int soNamCT;
    // Phương thức khởi tạo
    public NVVP(String hoTen, String loaiNV, int soNamCT){
        super(hoTen,loaiNV);
        this.soNamCT=soNamCT;
    }
    // Nhập thông tin
    void NhapTT(){
        super.NhapTT();
        loaiNV="Nhan vien van phong";
        Scanner inp=new Scanner(System.in);    
        System.out.print("\n - So nam cong tac: ");
        soNamCT=inp.nextInt();
    }
    // Tính lương
    float TinhLuong(){      
        int soLanTangLuong=soNamCT/3;
        float heSoLuong=soLanTangLuong*0.33f+HeSoLuongKhoiDiem;
        return heSoLuong*LCB;
    }
 
}
// 
/*
 Lớp cán bộ quản lý
 */

package lthdt_bai2_311016;
import java.util.Scanner;
/**
 *
 * @author tailieucntt.org
 */
public class CanBoQL extends NVVP {
    String chucVu;
    // Phương thức khởi tạo
    public CanBoQL(String hoTen, String loaiNV, int soNamCT, String chucVu){
        super(hoTen,loaiNV,soNamCT);
        this.chucVu=chucVu;      
    }
    // Nhâp thông tin
    void NhapTT(){
        super.NhapTT();
        loaiNV="Can bo quan ly";
        Scanner inp=new Scanner(System.in);    
        System.out.print("\n - Chuc vu: ");
        chucVu=inp.nextLine();
    }
    // Tính lương
    float TinhLuong(){
        int soLanTangLuong=soNamCT/3;
        float heSoLuong=soLanTangLuong*0.33f+HeSoLuongKhoiDiem;
        float phuCapChucVu=0;
        if(chucVu.equals("Truong Phong")) phuCapChucVu=2000000;
        if(chucVu.equals("Pho Phong")) phuCapChucVu=1500000;
        return heSoLuong*LCB+phuCapChucVu;
    }
}

//
/* Lớp chính ( LTHDT_Bai2_311016) */

package lthdt_bai2_311016;
import java.util.Scanner;
/**
 *
 * @author tailieucntt.org
 */
public class LTHDT_Bai2_311016 {
 
    public static void main(String[] args) {
        int so=0;  
        Scanner inp=new Scanner(System.in);
     
        do{
         System.out.print("\n \n * Ban vui long lua chon: ");  
         System.out.print("\n 1- Lap trinh vien ");
         System.out.print("\n 2- Nhan vien van phong");
         System.out.print("\n 3- Can bo quan ly ");
         System.out.print("\n 4- Thoat khoi chuong trinh");
          System.out.print("\n \n Chon doi tuong nhan vien: ");
         so=inp.nextInt();
         if(so<1||so>4)
            System.out.print("\n * Nhap sai, lua chon lai");
         else{
            if(so==1){
             LapTrinhVien nv1 =new LapTrinhVien("Nguyen Van A","Lap Trinh Vien",1);
             nv1.NhapTT();
             nv1.InTT();
            }
            if (so==2){
             NVVP nv2=new NVVP("Nguyen Van A","Lap Trinh Vien",1) ;
             nv2.NhapTT();
             nv2.InTT();
            }
            if (so==3){
             CanBoQL nv3=new CanBoQL("Nguyen Van A","Lap Trinh Vien",1,"Truong phong") ;
             nv3.NhapTT();
             nv3.InTT();
            }
         }
        }while(so!=4);
    }
 
}

 Lập trình Java - ĐH FPT

----------


Cùng bạn tự học CNTT - tailieucntt.org

Quảng cáo

Загрузка...

Categories

8051 (1) AI (1) AI programming (1) amazon (1) Android (27) ASP (1) Assembly (17) Bài giảng (2) Bài giảng lập trình C và Cpp (16) bài giảng quản lý dự án CNTT (1) bài tập java (1) bài tập lập trình (1) Bài viết hay (62) Bản đồ tư duy (1) Bidvertiser (1) Biểu diễn thuật toán (1) bitcoin (1) blockchain (1) Blockchain là gì (1) Bubble-Sort (1) C (77) C Plus Plus (103) C sharp (11) C++ (3) cấu trúc dữ liệu giải thuật (1) Cây (tree) (2) Cây quyết định (3) CDSL phân tán (1) Chữa bài tập Java (1) code assembly (1) Công nghệ điện toán đám mây (1) Công nghệ lập trình (1) Cơ sở dữ liệu (10) CSS (2) Cuộc cách mạng công nghiệp 4.0 (1) Danh ngôn lập trình (1) Danh sách liên kết (list) (1) Datamining (4) Đại số gia tử và ứng dụng (1) đăng ký Amazon (1) Đăng ký hosting (2) đặt hàng trên Amazon (1) Đệ quy (2) Đồ họa (4) Độ phức tạp của thuật toán (1) ebook-csdl (1) ebook-giaithuat (1) ebook-laptrinh (1) ebook-phancung-mang (1) ebook-tinhocungdung (1) ebook-web (1) Exceptions (1) Genetic Algorithm (1) Giải hệ phương trình tuyến tính (5) giải thuật (3) giải thuật Đệ quy (1) Giáo trình (2) Góc học tập (34) Góc suy ngẫm (1) Google App Engine (2) Heap-Sort (1) Hệ quản trị CSDL (1) Học lập trình (125) Học lập trình C và CPP qua ví dụ (15) học lập trình Java (7) HostGator (1) hợp ngữ (1) HPH (25) HTML (1) Hướng Dẫn Đăng Ký Tên Miền và Host Trên Hostgator (1) hướng dẫn mua host (1) hướng dẫn nhận tiền (1) hướng dẫn payoneer (1) Hướng dẫn sử dụng Emu8086 (1) hướng dẫn viết báo (1) hướng đăng ký tên miền (1) Insert-sort (2) iOS (1) Java (50) Java Căn bản (5) java core (3) Java GUI (1) JavaScript (3) Kiếm tiền online (10) Kỹ thuật đồ họa máy tính (9) Kỹ thuật lập trình (16) kỹ thuật SEO (1) Lập trình 8051 với C/C++ (1) Lập trình căn bản (7) Lập trình Cơ sở dữ liệu (2) Lập trình điều khiển thiết bị (1) Lập trình hợp ngữ (1) Lập trình hướng đối tượng (38) Lập trình hướng đối tượng với Java (6) Lập trình mạng (6) Lập trình mobile (3) Lập trình nhúng (1) Lập trình trí tuệ nhân tạo (1) lập trình vi xử lý (1) lập trình viên (1) Lập trình viên độc lập (1) Luyện thi IC3 (4) Lý thuyết Cơ sở dữ liệu (2) Lý thuyết đồ thị (11) Mạng máy tính (1) Mẹo tìm kiếm trên Google (1) Merge-Sort (1) MS Access (1) Mua hàng trên Amazon (1) Nghiên cứu khoa học (1) ngon-ngu-khac (1) Ngôn ngữ lập trình (1) Nhúng code Assembly trong C\C++ (2) Những lỗi thường gặp khi lập trình (1) Oracle (1) Pascal (3) payoneer (1) people-group (1) phần cứng máy tính (1) PHP (1) Quản lý dự án CNTT (1) Queue (hàng đợi) (1) Quick-Sort (1) Seclection-sort (2) SEO (1) SQL (5) Stack (ngăn xếp) (1) Swift (8) tài liệu CNTT miễn phí (2) Tài liệu tham khảo (2) thanh toán quốc tế (1) Thiết kế Web (2) Thủ thuật máy tính (5) thuattoan-khac (1) Thuật toán (41) Thuật toán di truyền (2) Thuật toán Đệ quy (4) Thuật toán K-Mean (1) Thuật toán khác (9) Thuật toán leo đồi (1) Thuật toán ma trận (7) Thuật toán Sắp Xếp -Sort (9) Thuật toán Tìm kiếm - Search (5) Thương mại điện tử (4) Tiện ích máy tính (3) Tìm hiểu Blockchain (1) Tìm kiếm nhị phân (2) Tìm kiếm tuần tự (Line search) (2) Tin học văn phòng (5) Tin tức công nghệ (7) Tính định thức của ma trận (1) Toán rời rạc (12) Trí tuệ nhân tạo (8) Tự học lập trình Android (14) Tự học lập trình C và CPP (14) tự học lập trình iOS (8) Tự học lập trình java qua các ví dụ (7) Ứng dụng cơ sở dữ liệu (1) VB (2) vẽ ngôi nhà (1) ví dụ Assembly (1) xcode (8) XML (1) Xử lý ma trận (mảng 2 chiều) (7) Xử lý mảng 1 chiều (1) Xử lý ngoại lệ (1)