北邮java oj作业1

1.

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStreamReader;

public class test1 {

    public static void main(String[] args) throws IOException {

        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

        // TODO Auto-generated method stub

        String inputString = br.readLine();

        int len = Integer.parseInt(inputString);

        int[][] a = new int[len + 1][len + 1];

        for(int i = 1;i <= len;i ++){

        for(int j = 1;j <= i; j++){

        a[i][j] = i * i - (j - 1);

        }

        for(int k = 1;k < i; k ++){

        a[k][i] = (i - 1) * (i - 1) + k;

        }

        }

        for(int i = 1;i <= len; i ++){

        for(int j = 1; j <= len; j ++){

            if(j==len)System.out.print(a[i][j]);

//每行最后一个数字

            else System.out.print(a[i][j] + " ");

//不是每行的最后一个数字,加空格

        }

        System.out.println();

        }

   

    }

}

2.

import java.util.Scanner;

public class test2{

    public static void main(String[] args) {

        Scanner in=new Scanner(System.in);

        double money,tax=0;

        money=in.nextDouble();

        if(money<=60000) tax=0;

        else if(money<=10000) tax=(money-60000)*0.03f;

        else if(money<=180000) tax=(100000-60000)*0.03f+(money-100000)*0.1f;

        else if(money<=300000) tax=(100000-60000)*0.03f+(180000-100000)*0.1f+(money-180000)*0.18f;

        else if(money<=480000) tax=(100000-60000)*0.03f+(180000-100000)*0.1f+(300000-180000)*0.18f+(money-300000)*0.25f;

        else if(money<=700000) tax=(100000-60000)*0.03f+(180000-100000)*0.1f+(300000-180000)*0.18f+(480000-300000)*0.25f+(money-480000)*0.3f;

        else if(money<=1000000) tax=(100000-60000)*0.03f+(180000-100000)*0.1f+(300000-180000)*0.18f+(480000-300000)*0.25f+(700000-480000)*0.3f+(money-700000)*0.35f;

        else if(money>1000000) tax=(100000-60000)*0.03f+(180000-100000)*0.1f+(300000-180000)*0.18f+(480000-300000)*0.25f+(700000-480000)*0.3f+(1000000-700000)*0.35f+(money-1000000)*0.45f;

        String result=String.format("%.2f",tax);

        System.out.println(result);   

        in.close();

    }

}

3.

import java.util.Scanner;

public class test3 {

    public static void main(String[] args)

    {

            System.out.println("请输入两个正整数:");

            Scanner in=new Scanner(System.in);

            String inputstr=in.nextLine();

            String[] strArray=inputstr.split(" ");

           

            int temp1=Integer.parseInt(strArray[0]);

            int temp2=Integer.parseInt(strArray[1]);

            int a[]=new int[5];

            int b[]=new int[5];

            int i=0,j=0,n=0,max;

            int count1=0,count2=0;//记录整数有多少位

             while (temp1!=0)

             {

                 a[i]=temp1%10;

                 temp1=temp1/10;

                 i=i+1;

                 count1++;

             }

             while (temp2!=0)

             {

                 b[j]=temp2%10;

                 temp2=temp2/10;

                 j=j+1;

                 count2++;

             }

            int k=count1+count2;

            int c[]=new int[10];

            for (i=0,j=count2-1;i<k;i++){

            if(i<count1

                System.out.print(a[count1-1-i]);

                if(j>=0) 

                System.out.print(b[j--]);

            }

          

        }

    }

4

import java.util.Scanner;

public class test4{

    public static void main(String[] args) {

        Scanner in=new Scanner(System.in);

        int N;

        N=in.nextInt();

        boolean[] isPrime = new boolean[N+1];

        for(int i=2;i<isPrime.length;i++) {

            isPrime[i]=true;

        }

        for(int i=2;i<isPrime.length;i++) {

            if(isPrime[i]==true) {

                for(int j=2;j*i<isPrime.length;j++) {

                    isPrime[j*i]=false;

                }

            }

        }

        for(int i=2;i<isPrime.length;i++) {

            if(isPrime[i]==true) System.out.print(i+" ");

        }

    }

}

5.

import java.util.Scanner;

import java.util.TreeSet;

public class test2{

    public static void main(String[] args) {

    Scanner in=new Scanner(System.in);

    String str=in.nextLine();

    in.close();

    String str1=sort(str);

    System.out.println(str1);

}

public static String sort(String str) {

    String[] array_str=str.split("");//将字符串转成字符数组

    TreeSet<String> treeSet=new TreeSet<String>();

    for(String s:array_str){//遍历字符数组

        treeSet.add(s);//将字符放入treeSet中,利用treeSet集合有序不重复的特性

    }

    String st ="";

    for(String s:treeSet){//遍历treeSet集合,在拼接到str字符串中

        st+=s;

        }

    return st;

    }

}

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
实验1 类的定义、对象数组的使用 1. 定义一个学生类(Student), 属性有 1)非静态属性String studentNumber 2)非静态属性String studentName 3)非静态属性int markForMaths 4)非静态属性int markForEnglish 5)非静态属性int markForScience 方法有: 1)构造方法Student(String number, String name) 2)构造方法Student() 3)String getNumber() 4)String getName() 5)void enterMarks(int markForMaths, int markForEnglish, int markForScience) 6)int getMathsMark() 7)int getEnglishMark() 8)int getScienceMark() 9)double calculateAverage() 10)String toString() 返回学生信息,包括学号、姓名、数学成绩、英语成绩、科学成绩、平均成绩。 注意:为了保证calculateAverage返回double类型,需要把三个分数的和除以3.0,而不是3. 另外,分数的初始值是什么?如果每个分数初始值为0,会造成混淆,分数为0表示还没有输入分数,还是分数确实为0?有更好的初始值吗? 编写Student类,并且编写一个StudentTest类,对Student类进行测试。 StudentTest类运行效果如下: 请输入学生学号:2011211301 请输入学生姓名:王晓 请输入学生三门课成绩(数学,英语,科学):88,79,90 学生信息如下: 学号:2011211301 姓名:王晓 数学成绩:88 英语成绩:79 科学成绩:90 平均成绩:85.66666666666667 2.定义一个StudentList类用来存储Student对象 属性有 1)Student[] list; //list存储学生对象 2)int total; //学生总人数 方法有: 1)StudentList(int length) //length是数组长度 2)boolean add(Student stu) //增加stu到数组中,成功,返回true,否则false 3)boolean remove(int no) //删除第no个数组元素,删除成功,返回true,否则false 4)boolean remove(Student number) //删除学号为number的学生,删除成功,返回true,否则false 5)boolean isEmpty() //判断数组是否为空,若是,返回true,否则false 6)Student getItem(int no) //返回第no个学生 7)Student getItem(Student number) //返回学号为number的学生,若该生不存在,返回null。 8) int getTotal() 返回学生总人数 编写StudentList类,并且编写一个StudentListTest类,对StudentList类进行测试。 StudentListTest类运行效果: 菜单如下,请输入 1~8代表您要执行的操作: 1. 增加1个学生 2. 根据学号删除学生 3. 根据位置删除学生 4. 判断是否为空 5.根据位置返回学生 6.根据学号返回学生 7. 输出全部学生信息 8.退出程序 请输入您的操作:1 请输入学生信息: 学号:2011211301 姓名:王晓 数学成绩:88 英语成绩:79 科学成绩:90 ---目前有1个学生,信息为---: 学号:2011211301 姓名:王晓 数学成绩:88 英语成绩:79 科学成绩:90 平均成绩:85.66666666666667 请输入您的操作:1 学号:2011211311 姓名:李辉 数学成绩:80 英语成绩:79 科学成绩:93 ---目前有2个学生,信息为---: 学号:2011211301 姓名:王晓 数学成绩:88 英语成绩:79 科学成绩:90 平均成绩:85.66666666666667 姓名:李辉 数学成绩:80 英语成绩:79 科学成绩:93 平均成绩:84.0 请输入您的操作:5 请输入学生位置:10 对不起,没有对应的学生 请输入您的操作:5 请输入学生位置:2 学生信息如下: 姓名:李辉 数学成绩:80 英语成绩:79 科学成绩:93 平均成绩:84.0 请输入您的操作:3 请输入要删除第几个学生:2 删除成功 ---目前有1个学生,信息为:

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值