一个简单的C#案例----002

博客主要围绕C#语言,利用LINQ实现学生信息处理。包括筛选名字含‘o’且年龄大于20的学生信息、对学生数组按年龄和ID排序、根据ID奇偶分组输出学生信息,以及按特定格式输出学生姓名和年龄等功能,还给出提示代码和补全后的代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述

补全代码,通过LINQ实现如下功能:
筛选数组studentArray,筛选条件是名字中包含‘o’的学生信息,并且年龄大于20,将满足条件的学生信息输出到命令行

提示代码

class Student{
public int StudentID { get; set; }
public String StudentName { get; set; }
public int Age { get; set; }
}class Program{
static void Main(string[] args) {
Student[] studentArray = {
new Student() { StudentID = 1, StudentName = “John”, Age = 18 },
new Student() { StudentID = 2, StudentName = “Steve”, Age = 21 },
new Student() { StudentID = 3, StudentName = “Bill”, Age = 25 },
new Student() { StudentID = 4, StudentName = “Ram” , Age = 20 },
new Student() { StudentID = 5, StudentName = “Ron” , Age = 31 },
new Student() { StudentID = 6, StudentName = “Chris”, Age = 17 },
new Student() { StudentID = 7, StudentName = “Rob”,Age = 19 },
};

    待补全
}

}

补全后的完整代码

class Student

{

    public int StudentID { get; set; }

    public String StudentName { get; set; }

    public int Age { get; set; }

}

class Program

{

    static void Main(string[] args)

    {

        Student[] studentArray = {

            new Student() { StudentID = 1, StudentName = "John", Age = 18 },

            new Student() { StudentID = 2, StudentName = "Steve",  Age = 21 },

            new Student() { StudentID = 3, StudentName = "Bill",  Age = 25 },

            new Student() { StudentID = 4, StudentName = "Ram" , Age = 20 },

            new Student() { StudentID = 5, StudentName = "Ron" , Age = 31 },

            new Student() { StudentID = 6, StudentName = "Chris",  Age = 17 },

            new Student() { StudentID = 7, StudentName = "Rob",Age = 19  },

        };



        for(int i = 0;i < studentArray.Length;i++)

        {

            if (studentArray[i].StudentName.Contains('o') && studentArray[i].Age > 20)

            {

                Console.WriteLine("StudentID: " + studentArray[i].StudentID + " "+ " StudentName: " +studentArray[i].StudentName + " " + " Age: " + studentArray[i].Age);

            }

        }



    }

}

效果图

在这里插入图片描述


描述

补全代码,通过LINQ实现如下功能:
将数组studentArray排序,要求根据年龄排序,如果年龄相同,根据StudentID排序,将排序后的学生信息输出到命令行

提示代码

同上

补全后的代码

class Student

{

    public int StudentID { get; set; }

    public String StudentName { get; set; }

    public int Age { get; set; }

}

class Program

{

    static void Main(string[] args)

    {

        Student[] studentArray = {

            new Student() { StudentID = 1, StudentName = "John", Age = 18 },

            new Student() { StudentID = 2, StudentName = "Steve",  Age = 21 },

            new Student() { StudentID = 3, StudentName = "Bill",  Age = 25 },

            new Student() { StudentID = 4, StudentName = "Ram" , Age = 20 },

            new Student() { StudentID = 5, StudentName = "Ron" , Age = 31 },

            new Student() { StudentID = 6, StudentName = "Chris",  Age = 17 },

            new Student() { StudentID = 7, StudentName = "Rob",Age = 19  },

        };

        studentArray = studentArray.OrderBy(x => x.Age).ThenByDescending(x => x.StudentID).ToArray();



        Console.WriteLine("StudentID\t" + "StudentName\t" + "Age\t");

        for (int i = 0; i < studentArray.Length; i++)

        {

            Console.WriteLine(" " + studentArray[i].StudentID + "\t\t " + studentArray[i].StudentName + "\t\t " + studentArray[i].Age);

        }

    }

}


效果图

在这里插入图片描述


描述

补全代码,通过LINQ实现如下功能:
根据SudentID进行分组,输出SudengtId分别为奇数/偶数的学生信息

提示代码

同上

补全后的代码

class Student

{

    public int StudentID { get; set; }

    public String StudentName { get; set; }

    public int Age { get; set; }

    public bool Key { get; internal set; }

}

class Program

{

    static void Main(string[] args)

    {

        Student[] studentArray = {

            new Student() { StudentID = 1, StudentName = "John", Age = 18 },

            new Student() { StudentID = 2, StudentName = "Steve",  Age = 21 },

            new Student() { StudentID = 3, StudentName = "Bill",  Age = 25 },

            new Student() { StudentID = 4, StudentName = "Ram" , Age = 20 },

            new Student() { StudentID = 5, StudentName = "Ron" , Age = 31 },

            new Student() { StudentID = 6, StudentName = "Chris",  Age = 17 },

            new Student() { StudentID = 7, StudentName = "Rob",Age = 19  },

        };

        var query = from stu in studentArray group stu by stu.StudentID % 2;

        foreach(var student in query) { 

            Console.WriteLine(student.Key == 0 ? "----------------偶数----------------" : "----------------奇数----------------");

            Console.WriteLine("StudentID\t" + "StudentName\t" + "Age\t");

            foreach (var item in student)

            {

                Console.WriteLine(" " + item.StudentID + "\t\t " + item.StudentName + "\t\t " + item.Age);

            }

        }

    }

}

效果图

在这里插入图片描述


描述

补全代码,通过LINQ实现如下功能:
输出sudengtArray信息,要求不输出SudengtID字段,输出SudengtName和Age,其中SudengtName要求根据Gender增加Mr. 和Ms. 前缀

提示代码

class Student{
public int StudentID { get; set; }
public String StudentName { get; set; }
public int Age { get; set; }
public String Gender { get; set; }
}class Program{
static void Main(string[] args) {
Student[] studentArray = {
new Student() { StudentID = 1, StudentName = “John”, Age = 18, Gender = “Male” },
new Student() { StudentID = 2, StudentName = “Steve”, Age = 21, Gender = “Male” },
new Student() { StudentID = 3, StudentName = “Bill”, Age = 25, Gender = “Male” },
new Student() { StudentID = 4, StudentName = “Ram” , Age = 21, Gender = “Male” },
new Student() { StudentID = 5, StudentName = “Ron” , Age = 31, Gender = “Female” },
new Student() { StudentID = 6, StudentName = “Chris”, Age = 17, Gender = “Female” },
new Student() { StudentID = 7, StudentName = “Rob”,Age = 19, Gender = “Male” },
};

    //待补全...
}

}

补全后的代码

class Student

{

    public int StudentID { get; set; }

    public String StudentName { get; set; }

    public int Age { get; set; }

    public String Gender { get; set; }

}

class Program

{

    static void Main(string[] args)

    {

        Student[] studentArray = {

            new Student() { StudentID = 1, StudentName = "John", Age = 18, Gender = "Male" },

            new Student() { StudentID = 2, StudentName = "Steve",  Age = 21, Gender = "Male" },

            new Student() { StudentID = 3, StudentName = "Bill",  Age = 25, Gender = "Male" },

            new Student() { StudentID = 4, StudentName = "Ram" , Age = 21, Gender = "Male" },

            new Student() { StudentID = 5, StudentName = "Ron" , Age = 31, Gender = "Female" },

            new Student() { StudentID = 6, StudentName = "Chris",  Age = 17, Gender = "Female" },

            new Student() { StudentID = 7, StudentName = "Rob",Age = 19, Gender = "Male"  },

        };

        var query = from stu in studentArray where stu.Age > 0 select stu;

        Console.WriteLine("StudentName\t" + "Age");

        foreach (var student in query)

        {

            

            if (student.Gender != "Male")

            {

                Console.WriteLine("Ms." + student.StudentName + "\t\t" + student.Age);

            } else

            {

                Console.WriteLine("Mr." + student.StudentName + "\t\t" + student.Age);

            }



        }



    }

}

效果图

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张居然的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值