「java成绩排序」java成绩排序代码

博主:adminadmin 2022-11-22 17:44:06 82

今天给各位分享java成绩排序的知识,其中也会对java成绩排序代码进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

java排序成绩排名,升序怎么排 坐等答案

java跟c++差不多,c++中的排序Java中都可以用,排序部分代码完全一样,比如常用的选择排序:

double temp;  //后面用来临时接收数据

int index;

//score[] 是成绩数组,假设是double类型,共n个数据元素

for(int i = 0; i  n; i++) {      //每执行一次外循环,都能得到未排序的数据中的一个最小值

    temp = score[i];

    for(int j = 0; j  n; j++) {

        if(temp  score[j]) {

            temp = score[j];

            index = j;

        }

    }

    score[index] = score[i];

    score[i] = temp;

}

java语言对几个同学的成绩进行排序

package test;

import java.util.Scanner;

public class test{

public static void main(String[] args)

{

test ts = new test();

Scanner sc = new Scanner(System.in); //Scanner类的构造方法。

int a[] = new int[10];

System.out.println("输入10个同学的成绩,中间以空格隔开");

for (int i = 0; i a.length; i++) {

a[i] = sc.nextInt(); //依次输入数字中间以空格隔开。

}

test.maopao(a); //调用排序方法。

for (int i = 0; i a.length; i++)

System.out.println(a[i]);

}

public static void maopao(int array[]) { //定义冒泡排序方法。

int i;

int k;

for (i = 0; i array.length; i++) {

for (k = 0; k array.length - 1 - i; k++) {

if (array[k] array[k + 1]) {

int temp = array[k];

array[k] = array[k + 1];

array[k + 1] = temp;

}

}

}

}

}

设计一个给班级学生成绩排序的java程序,具体要求如下

按照题目要求编写的Java程序如下(注意 以下程序全部放在Main.java文件中)

class student{

String name;

int score;

public student(String name,int score){

this.name=name;

this.score=score;

}

String studentInfo(){

return "name="+this.name+",score="+this.score;

}

}

public class Main{

public static void main(String[] args){

student sty[]=new student[5];

sty[0]=new student("zhangsan",67);

sty[1]=new student("lisi",75);

sty[2]=new student("wangwu",57);

sty[3]=new student("zhaoliu",88);

sty[4]=new student("ruanqi",93);

student stu[]=new student[5];

for(int i=0;isty.length;i++){

stu[i]=sty[i];

}

for(int i=0;istu.length-1;i++){

for(int j=0;jstu.length-i-1;j++){

  if(stu[j].scorestu[j+1].score){

   student temp=stu[j];

   stu[j]=stu[j+1];

   stu[j+1]=temp;

  }

}

}

for(int i=0;istu.length;i++){

System.out.println(stu[i].studentInfo());

}

}

}

java语言做成绩排名表,如何实现同分同名次,最好有代码,谢谢

思路: 排序肯定还是要排的, 按照Java成绩来进行排练. 然后排名的时候,进行比较. 如果这一名的成绩和上一名的相同, 那么名次相同, 如果比上一名分数低,那么排名加一.

可以使用传统的,集合排序,输出. 也可以使用java8新提供的Stream API进行操作

参考代码如下

import java.util.*;

import java.util.Map.Entry;

import java.util.stream.Collectors;

class Stu {// 学生类

private String name;

private double score;// 成绩

public Stu(String name, double score) {

this.name = name;

this.score = score;

}

public double getScore() {

return score;

}

public void setScore(double score) {

this.score = score;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

//测试类

public class TestDemo {

public static void main(String[] args) {

ListStu stus = Arrays.asList(new Stu("Tom", 79.5), new Stu("Jack", 52), new Stu("Amdy", 79.5),

new Stu("Lucy", 68), new Stu("Cherry", 79.5), new Stu("Jerry", 52), new Stu("Sweet", 91),

new Stu("Solem", 65));

fun1(stus);

System.out.println("---------------分割线---------------------");

fun2(stus);

}

// 方法一:传统的方法

public static void fun1(ListStu stus) {

// 按照成绩排序

stus.sort(new ComparatorStu() {

@Override

public int compare(Stu s1, Stu s2) {

return -Double.compare(s1.getScore(), s2.getScore());

}

});

int index = 0;// 排名

double lastScore = -1;// 最近一次的分

for (int i = 0; i  stus.size(); i++) {

Stu s = stus.get(i);

if (Double.compare(lastScore, s.getScore())!=0) { // 如果成绩和上一名的成绩不相同,那么排名+1

lastScore = s.getScore();

index++;

}

System.out.println("名次:" + index + "\t分数" + s.getScore() + "\t名字" + s.getName());

}

}

// 方法2: Java8开始支持的Lambada表达式配合 Stream API 来进行分组排序

public static void fun2(ListStu stus) {

ListEntryDouble, ListStu list = stus.stream().collect(Collectors.groupingBy(Stu::getScore)).entrySet()

.stream().sorted((s1, s2) - -Double.compare(s1.getKey(), s2.getKey())).collect(Collectors.toList());

int index = 1;

for (EntryDouble, ListStu entry : list) {

System.out.print("名次:" + index + "\t分数:" + entry.getKey() + "\t名字");

entry.getValue().forEach((s) - System.out.print("  " + s.getName()));

System.out.println();

index++;

}

}

}

输出结果

名次:1 分数91.0 名字Sweet

名次:2 分数79.5 名字Tom

名次:2 分数79.5 名字Amdy

名次:2 分数79.5 名字Cherry

名次:3 分数68.0 名字Lucy

名次:4 分数65.0 名字Solem

名次:5 分数52.0 名字Jack

名次:5 分数52.0 名字Jerry

名次:1 分数:91.0 名字  Sweet

名次:2 分数:79.5 名字  Tom  Amdy  Cherry

名次:3 分数:68.0 名字  Lucy

名次:4 分数:65.0 名字  Solem

名次:5 分数:52.0 名字  Jack  Jerry

---------------分割线---------------------

名次:1 分数:91.0 名字  Sweet

名次:2 分数:79.5 名字  Tom  Amdy  Cherry

名次:3 分数:68.0 名字  Lucy

名次:4 分数:65.0 名字  Solem

名次:5 分数:52.0 名字  Jack  Jerry

关于java成绩排序和java成绩排序代码的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

The End

发布于:2022-11-22,除非注明,否则均为首码项目网原创文章,转载请注明出处。