定义抽象类Person、派生类Student和类Teacher(C#实现)

设计抽象类Person,派生出具体类:学生类Student和教师类Teacher,创建若干不同类对象后并在主方法中测试。
数据成员定义:
Person [ID,姓名,生日]
Student [专业,成绩]
Teacher [职称,工资]
带参构造方法分别为:
Person(int id,String name, int bir)
Student(int id,String name, int bir, String major,double score)
Teacher(int id,String name, int bir, String title, double salary)
toString方法(Eclipse自动生成)

输入格式:

第一行整数n表示有n个对象,每个对象占2行,第一行为数字0(表示学生)或1(表示教师),第二行为生成对象的参数。

输出格式:

按行输出具体对象的信息。

输入样例:

在这里给出一组输入。例如:

5
0
10101 Peter 20010121 Computer 87.5
1
20110014 Crystal 19900103 AI 7000
0
10102 Rose 20010715 E-Commerce 90
1
20120019 David 19781218 Prof 12000
0
10103 Semon 20000405 Computer 88

输出样例:

在这里给出相应的输出。例如:

Student [id=10101, name=Peter, bir=20010121, major=Computer, score=87.5]
Teacher [id=20110014, name=Crystal, bir=19900103, title=AI, salary=7000.0]
Student [id=10102, name=Rose, bir=20010715, major=E-Commerce, score=90.0]
Teacher [id=20120019, name=David, bir=19781218, title=Prof, salary=12000.0]
Student [id=10103, name=Semon, bir=20000405, major=Computer, score=88.0]


解答:要注意是全部一次性输入,并且要注意题目最后的格式要保留一位小数

using System;

namespace _7_13_定义抽象类Person_派生类Student和类Teacher
{
    internal class Program
    {
        static void Main(string[] args)
        {
            int i =int.Parse(Console.ReadLine());
            Person[] people = new Person[i];
            for(int a = 0; a < i; a++)
            {
                int b = int.Parse(Console.ReadLine());
                if(b== 0)
                {
                    string arr=Console.ReadLine();
                    string[] arr1 = arr.Split(' ');
                    int id=int.Parse(arr1[0]);
                    int bir=int.Parse(arr1[2]);
                    double score=double.Parse(arr1[4]);
                    people[a] = new Student(id, arr1[1], bir, arr1[3], score);
                }
                else if (b == 1)
                {
                    string arr = Console.ReadLine();
                    string[] arr1 = arr.Split(' ');
                    int id = int.Parse(arr1[0]);
                    int bir = int.Parse(arr1[2]);
                    double salary = double.Parse(arr1[4]);
                    people[a] = new Teacher(id, arr1[1], bir, arr1[3], salary);
                }
                else
                {
                    break;
                }
                }
            foreach(var item in people)
            {
                Console.WriteLine(item.ToString());
                
            }
            }
        }
    }

    public abstract class Person
    {
        private int _id;
        private string _name;
        private int _bir;
        public int Id { get; set; }
        public string Name { get; set; }
        public int Bir { get; set; }
        public Person(int id, string name, int bir)
        {
            this.Id = id;
            this.Name = name;
            this.Bir = bir;
        }
    }
    public class Student : Person
    {
        private string _major;
        private double _score;
        public string Major { get; set; }
        public double Score { get;set; }
        public Student(int id,string name,int bir,string major,double score) : base(id, name, bir)
        {
            this.Id=id;
            this.Name = name;
            this.Bir=bir;
            this.Major = major;
            this.Score=score;
        }
        public override string ToString()
        {
            return "Student [id=" + this.Id + ", name=" + this.Name + ", bir=" + this.Bir + ", major=" + this.Major + ", score=" + this.Score.ToString("#0.0") + "]";
        }
    } 
    public class Teacher : Person
    {
        private string _title;
        private double _salary;
        public string Title { get; set; }
        public double Salary { get; set; }
        public Teacher(int id,string name,int bir,string title,double salary) : base(id, name, bir)
        {
            this.Id = id;
            this.Name = name;
            this.Bir = bir;
            this.Title = title;
            this.Salary = salary;
        }  
        public override string ToString()
        {
            return "Teacher [id="+this.Id+", name="+this.Name+", bir="+this.Bir+", title="+this.Title+", salary="+this.Salary.ToString("#0.0") + "]";
        }

    }

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 抽象类 "Person" 是一个抽象的,它定义了人的共同特征,但不能被直接使用。 派生类 "Student" 是从抽象类 "Person" 派生来的一个,它继承了抽象类 "Person" 的所有特征,并且可以定义学生的特有特征。 "Teacher" 是另一个派生类,它也从抽象类 "Person" 派生来,它继承了抽象类 "Person" 的所有特征,并且可以定义教师的特有特征。 ### 回答2: 抽象类是指不能被实例化的,通常用于描述共性特征,同时规定子必须实现其抽象方法或抽象属性。在面向对象编程中,抽象类是一种重要的概念,常常用于设计实现基础框架。 在定义抽象类Person时,我们可以考虑以下属性和方法: 属性: - 姓名 name - 年龄 age - 性别 gender 方法: - 获取姓名 getName() - 获取年龄 getAge() - 获取性别 getGender() - 显示信息 display() 在派生类Student中,我们可以继承Person,同时添加一些新的属性和方法: 属性: - 学号 id - 专业 major 方法: - 获取学号 getId() - 获取专业 getMajor() - 显示信息 display() 在Teacher中,我们也可以继承Person,同时添加一些新的属性和方法: 属性: - 工号 id - 职称 title 方法: - 获取工号 getId() - 获取职称 getTitle() - 显示信息 display() 我们可以将上述的关系表现为:PersonStudent和Teacher的父,而Student和Teacher都是Person的子。 在使用抽象类时,我们可以体现其优越性。例如,我们可以在Person定义一些公共方法,这些方法可以被子继承和复用。另外,由于抽象类不能被实例化,因此也可以保证程序的安全性。 在具体实现时,我们可以按照以下方式定义抽象类Person派生类StudentTeacher: public abstract class Person { protected String name; protected int age; protected String gender; public Person(String name, int age, String gender) { this.name = name; this.age = age; this.gender = gender; } public abstract String getName(); public abstract int getAge(); public abstract String getGender(); public abstract void display(); } public class Student extends Person { private int id; private String major; public Student(String name, int age, String gender, int id, String major) { super(name, age, gender); this.id = id; this.major = major; } public int getId() { return id; } public String getMajor() { return major; } @Override public String getName() { return name; } @Override public int getAge() { return age; } @Override public String getGender() { return gender; } @Override public void display() { System.out.println("Name: " + name); System.out.println("Age: " + age); System.out.println("Gender: " + gender); System.out.println("ID: " + id); System.out.println("Major: " + major); } } public class Teacher extends Person { private int id; private String title; public Teacher(String name, int age, String gender, int id, String title) { super(name, age, gender); this.id = id; this.title = title; } public int getId() { return id; } public String getTitle() { return title; } @Override public String getName() { return name; } @Override public int getAge() { return age; } @Override public String getGender() { return gender; } @Override public void display() { System.out.println("Name: " + name); System.out.println("Age: " + age); System.out.println("Gender: " + gender); System.out.println("ID: " + id); System.out.println("Title: " + title); } } 通过以上代码,我们可以看,使用继承和抽象类的方式,可以简洁地实现定义和组织。 定义抽象类Person派生类StudentTeacher,是一个典型的面向对象编程案例。 ### 回答3: 抽象类Person是一个基,它定义了人的基本属性和方法。它包含了姓名、性别、年龄等基本属性,以及eat()、sleep()、work()等方法。由于Person是一个抽象类,因此不能被实例化,只能作为基被继承。 派生类Student继承了Person,它代表了一个学生。Student有自己的特定属性和方法,比如班级、学号、考试成绩等。它必须实现Person的抽象方法,并可以添加自己的方法。 Teacher也是Person的一个派生类,它代表了一个教师。Teacher有自己的特定属性和方法,比如教授的课程、授课时间等。它必须实现Person的抽象方法,并可以添加自己的方法。同时,Teacher还可以包含一些特定于教师的方法和属性,比如评估学生表现、制定课程计划等。 在这个的层次结构中,Person是基,它包含了所有人共有的特征和行为;Student和TeacherPerson派生类,它们在Person基础上增加了一些自己的属性和方法,并且保持了Person的一些基本属性和方法。这个的层次结构可以帮助我们更好地管理人的信息,同时也方便了代码的重用和维护。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值