import java.text.DecimalFormat;
 import java.util.Arrays;
 import java.util.Scanner;

 /*
  * 作者:Chensx1020
  * 时间:2016-12-11
  * 功能:CPU调度算法
  *         1)先到先服务调度算法(FCFS)
  *         2)最短作业优先调度算法,非抢占式(SJF)
  *         3)优先级调度算法(PSA)
  *         4)轮转法调度算法(RR)
  *         5)最高响应比调度算法(HRR)
  *         6)最短作业优先调度算法,抢占式(SJF)
  */

 public class CPU {
     //排序方法
     public static String whichComp="FCFS";
     //时间片
     public static int timeSlice=4;

     //进程类...............................................................
     public static class MyProcess implements Comparable<MyProcess> {

         private String name;    //进程名字
         private int arrive;    //到达时间
         private int work;    //区间时间(服务时间)
         private int rWork;    //还需时间
         private int priority;    //优先级
         private int begin;    //开始时间
         private double hrr;    //响应比
         private boolean flag;    //标记该进程是否执行

         public MyProcess(String name){
             this.name = name;
             this.flag = false;
         }

         public void setArrive(int arrive){
             this.arrive = arrive;
         }
         public void setWork(int work){
             this.work = work;
         }
         public void setRwork(int rWork){
             this.rWork = rWork;
         }
         public void setPriority(int priority){
             this.priority = priority;
         }
         public void setBegin(int begin){
             this.begin = begin;
         }
         public void setHrr(){
             this.hrr = (this.begin-this.arrive)*1.0/this.work + 1;
         }
         public void setHrr(double hrr){
             this.hrr = hrr;
         }
         public void setFlag(){
             this.flag = true;
         }

         public String getName(){
             return this.name;
         }
         public int getArrive(){
             return this.arrive;
         }
         public int getWork(){
             return this.work;
         }
         public int getRwork(){
             return this.rWork;
         }
         public int getPriority(){
             return this.priority;
         }
         public int getBegin(){
             return this.begin;
         }
         public double getHrr(){
             return this.hrr;
         }
         public boolean getFlag(){
             return this.flag;
         }

         @Override
         public int compareTo(MyProcess o) {
             if(whichComp.equals("FCFS")){
                 if(this.arrive>o.arrive)
                     return 1;
                 else if(this.arrive<o.arrive)
                     return -1;
                 else
                     return this.work-o.work;
             }
             else if(whichComp.equals("SJF")){
                 if(this.work>o.work)
                     return 1;
                 else if(this.work<o.work)
                     return -1;
                 else
                     return this.arrive-o.arrive;
             }
             else if(whichComp.equals("SJFS")){
                 if(this.rWork>o.rWork)
                     return 1;
                 else if(this.rWork<o.rWork)
                     return -1;
                 else
                     return this.arrive-o.arrive;

             }
             else if(whichComp.equals("PSA")){
                 if(this.priority>o.priority)
                     return 1;
                 else if(this.priority<o.priority)
                     return -1;
                 else
                     return this.arrive-o.arrive;
             }
             else if(whichComp.equals("HRR")){
                 if(this.begin>o.begin)
                     return 1;
                 else if(this.begin<o.begin)
                     return -1;
                 else{
                     if(this.hrr < o.hrr)
                         return 1;
                     else if(this.hrr > o.hrr)
                         return -1;
                     else{
                         return this.arrive-o.arrive;
 //                        if(this.arrive>o.arrive)
 //                            return 1;
 //                        else if(this.arrive<o.arrive)
 //                            return -1;
 //                        else
 //                            return this.work-o.work;
                     }
                 }
             }
             else{
                 return 0;
             }
         }
     }

     //FCFS类...............................................................
     public static class FCFS{

         private int count;
         private String temp;

         public FCFS(MyProcess test[]){
             Arrays.sort(test);

             count = test[0].getArrive();
             temp = "";

             int length = test.length;

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("先到先服务调度算法的结果为:");
             System.out.println("进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t等待时间\t"
                     + "周转时间\t带权周转时间\t");

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

                 System.out.println(test[i].getName()+"\t"
                         +test[i].getArrive()+"\t"
                         +test[i].getWork()+"\t"
                         +count+"\t"
                         +(count+test[i].getWork())+"\t"
                         +(count-test[i].getArrive())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())*1.0/test[i].getWork()+"\t"
                         );

                 wait += count-test[i].getArrive();
                 cycle += count-test[i].getArrive()+test[i].getWork();

                 count += test[i].getWork();

                 if(count < test[i+1].getArrive())
                     count = test[i+1].getArrive();
                 temp += test[i].getName()+"   ";

             }

             System.out.println(test[length-1].getName()+"\t"
                     +test[length-1].getArrive()+"\t"
                     +test[length-1].getWork()+"\t"
                     +count+"\t"
                     +(count+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())*1.0/test[length-1].getWork()+"\t"
                     );

             wait += count-test[length-1].getArrive();
             cycle += count-test[length-1].getArrive()+test[length-1].getWork();

             temp += test[test.length-1].getName()+"   ";

             System.out.println("\n所以最后先到先服务调度算法执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);
         }

     }

     //SJF类非抢占式...............................................................
     public static class SJF{

         private int count;
         private String temp;

         public SJF(MyProcess test[]){
             Arrays.sort(test);

             count = test[0].getArrive();
             temp = "";

             int length = test.length;

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("最短作业优先调度算法非抢占式的结果为:");
             System.out.println("进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t等待时间\t"
                     + "周转时间\t带权周转时间\t");

             for(int i=0; i<length-1; ++i){
                 System.out.println(test[i].getName()+"\t"
                         +test[i].getArrive()+"\t"
                         +test[i].getWork()+"\t"
                         +count+"\t"
                         +(count+test[i].getWork())+"\t"
                         +(count-test[i].getArrive())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())*1.0/test[i].getWork()+"\t"
                         );

                 wait += count-test[i].getArrive();
                 cycle += count-test[i].getArrive()+test[i].getWork();

                 count += test[i].getWork();

                 if(count < test[i+1].getArrive())
                     count = test[i+1].getArrive();
                 temp += test[i].getName()+"   ";

             }

             System.out.println(test[length-1].getName()+"\t"
                     +test[length-1].getArrive()+"\t"
                     +test[length-1].getWork()+"\t"
                     +count+"\t"
                     +(count+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())*1.0/test[length-1].getWork()+"\t"
                     );

             wait += count-test[length-1].getArrive();
             cycle += count-test[length-1].getArrive()+test[length-1].getWork();

             temp += test[test.length-1].getName()+"   ";

             System.out.println("\n所以最后最短作业优先调度算法非抢占式执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);
         }

     }

     //SJF类抢占式...............................................................
     public static class SJFS{

         private int count;
         private String temp;    //执行的顺序
         private int flag = 0;    //计数,用于判断是否所有进程执行完毕

         public SJFS(MyProcess test[]){

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("最短作业优先调度算法抢占式的结果为:");
             System.out.println("进程名字\t到达时间\t区间时长\t开始时间\t结束时间\t剩余服务时间\t等待时间\t"
                     + "周转时间\t带权周转时间\t");

             int length = test.length;    //长度

             whichComp="FCFS";
             Arrays.sort(test);    //按照进程的到达时间排序
             count = test[0].getArrive();    //count的值为程序最先到达的进程的到达时间

             whichComp="SJFS";
             Arrays.sort(test);     //所有进程按照剩余服务时间的长短排序

             String lastName = "";    //上一次执行的进程的名字
             for(int i=0; i<length; ++i){
                 if(test[i].getArrive()<=count){
                     lastName = test[i].getName();
                     System.out.print(test[i].getName() + "\t"
                             + test[i].getArrive() + "\t"
                             + test[i].getWork() + "\t"
                             + count + "\t");
                     temp = test[i].getName()+"   ";
                     break;
                 }
             }

             boolean done = false;

             while(true){
                 done = false;
                 ++count;

                 for(int j=0; j<length; ++j){
                     if(test[j].getName().equals(lastName)){
                         test[j].setRwork(test[j].getRwork()-1);    //剩余时间-1
                         if(test[j].getRwork() == 0){
                             ++flag;
                             test[j].setRwork(999999999);
                             System.out.println(count + "\t"
                                     + "0\t\t"
                                     + (count-test[j].getWork()-test[j].getArrive()) + "\t"    //等待时间
                                     + (count-test[j].getArrive()) + "\t"                        //周转时间
                                     + ((count-test[j].getArrive())*1.0/test[j].getWork()) + "\t" //带权周转
                                     );
                             wait += count-test[j].getWork()-test[j].getArrive();
                             cycle += count-test[j].getArrive();
                             done = true;
                         }
                         break;
                     }
                 }

                 if(flag==length){
                     break;
                 }

                 Arrays.sort(test);     //所有进程按照剩余服务时间的长短重新排序

                 for(int i=0; i<length; ++i){
                     if(test[i].getArrive()<=count){
                         if(lastName.equals(test[i].getName())){
 //                            System.out.println(test[i].getName());
                         }
                         else{
                             for(int j=0; j<length; ++j){
                                 if(test[j].getName().equals(lastName)){
                                     if(!done){
                                         System.out.println(count + "\t"
                                                 + test[j].getRwork()+ "\t\t"
                                                 + "未执行完\t" + "未执行完\t" + "未执行完\t");
                                     }
                                 }
                             }

                             lastName = test[i].getName();

                             System.out.print(test[i].getName() + "\t"
                                     + test[i].getArrive() + "\t"
                                     + test[i].getWork() + "\t"
                                     + count + "\t");
                             temp += test[i].getName()+"   ";
                         }
                         break;
                     }
                 }

             }

             System.out.println("\n所以最后最短作业优先调度算法抢占式执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);

         }

     }

     //PSA类...............................................................
     public static class PSA{

         private int count;
         private String temp;

         public PSA(MyProcess test[]){
             Arrays.sort(test);

             count = test[0].getArrive();
             temp = "";

             int length = test.length;

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("优先级调度算法的结果为:");
             System.out.println("进程名字\t到达时间\t服务时间\t优先级\t开始时间\t结束时间\t等待时间\t"
                     + "周转时间\t带权周转时间\t");

             for(int i=0; i<length-1; ++i){
                 System.out.println(test[i].getName()+"\t"
                         +test[i].getArrive()+"\t"
                         +test[i].getWork()+"\t"
                         +test[i].getPriority()+"\t"
                         +count+"\t"
                         +(count+test[i].getWork())+"\t"
                         +(count-test[i].getArrive())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())+"\t"
                         +(count-test[i].getArrive()+test[i].getWork())*1.0/test[i].getWork()+"\t"
                         );

                 wait += count-test[i].getArrive();
                 cycle += count-test[i].getArrive()+test[i].getWork();

                 count += test[i].getWork();

                 if(count < test[i+1].getArrive())
                     count = test[i+1].getArrive();
                 temp += test[i].getName()+"   ";

             }

             System.out.println(test[length-1].getName()+"\t"
                     +test[length-1].getArrive()+"\t"
                     +test[length-1].getWork()+"\t"
                     +test[length-1].getPriority()+"\t"
                     +count+"\t"
                     +(count+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())+"\t"
                     +(count-test[length-1].getArrive()+test[length-1].getWork())*1.0/test[length-1].getWork()+"\t"
                     );

             wait += count-test[length-1].getArrive();
             cycle += count-test[length-1].getArrive()+test[length-1].getWork();

             temp += test[test.length-1].getName()+"   ";

             System.out.println("\n所以最后优先级调度算法执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);
         }

     }

     //HRR类...............................................................
     public static class HRR{

         private int count;
         private String temp;

         public HRR(MyProcess test[], MyProcess tests[]){

             DecimalFormat df = new DecimalFormat("#.###");     //小数保留三位小数  

             Arrays.sort(tests);

             count = tests[0].getBegin();
             temp = "";

             int length = test.length;

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("最高响应比调度算法的结果为:");

             for(int tur = 1; tur<=length; ++tur){
                 System.out.println("\n正在执行第"+tur+"个进程:"+tests[0].getName());
                 System.out.println("进程名字\t到达时间\t服务时间\t响应比\t开始时间\t结束时间\t等待时间\t"
                         + "周转时间\t带权周转时间\t");    

                 for(int i=0; i<length; ++i) {

                     if(test[i].getFlag()){    //已执行
                         System.out.println(test[i].getName()+"\t"
                                 +test[i].getArrive()+"\t"
                                 +test[i].getWork()+"\t"
                                 +"已执行完\t"
                                 +test[i].getBegin()+"\t"
                                 +(test[i].getBegin()+test[i].getWork())+"\t"
                                 +(test[i].getBegin()-test[i].getArrive())+"\t"
                                 +(test[i].getBegin()-test[i].getArrive()+test[i].getWork())+"\t"
                                 +df.format((test[i].getBegin()-test[i].getArrive()+test[i].getWork())*1.0/test[i].getWork())+"\t"
                                 );
                         continue;
                     }

                     else if(test[i].getArrive()>count){    //未到达
                         System.out.println(test[i].getName()+"\t"
                                 +test[i].getArrive()+"\t"
                                 +test[i].getWork()+"\t"
                                 +"未到达\t"
                                 +"未到达\t"
                                 +"未到达\t"
                                 +"未到达\t"
                                 +"未到达\t"
                                 +"未到达\t"
                                 );
                         continue;
                     }

                     else{
                         //执行该进程
                         if(test[i].getName().equals(tests[0].getName())){
                             System.out.println(test[i].getName()+"\t"
                                     +test[i].getArrive()+"\t"
                                     +test[i].getWork()+"\t"
                                     +df.format(test[i].getHrr())+"\t"
                                     +test[i].getBegin()+"\t"
                                     +(test[i].getBegin()+test[i].getWork())+"\t"
                                     +(test[i].getBegin()-test[i].getArrive())+"\t"
                                     +(test[i].getBegin()-test[i].getArrive()+test[i].getWork())+"\t"
                                     +df.format((test[i].getBegin()-test[i].getArrive()+test[i].getWork())*1.0/test[i].getWork())+"\t"
                                     );

                             wait += test[i].getBegin()-test[i].getArrive();
                             cycle += test[i].getBegin()-test[i].getArrive()+test[i].getWork();
                             test[i].setFlag();
                             tests[0].setFlag();
                         }

                         else{
                             System.out.println(test[i].getName()+"\t"
                                     +test[i].getArrive()+"\t"
                                     +test[i].getWork()+"\t"
                                     +df.format(test[i].getHrr())+"\t"
                                     +"未开始\t"
                                     +"未开始\t"
                                     +"未开始\t"
                                     +"未开始\t"
                                     +"未开始\t"
                                     );
                         }

                     }
                 }

                 int count1=count+tests[0].getWork();

                 for(int j=tests.length-1; j>=1; --j){
                     if(tests[j].getFlag()){
                         ;
                     }
                     else{
                         if(count1 >= tests[j].getArrive()){    //进程已到
                             tests[j].setBegin(count1);
                             int x;
                             for(x=0; x<length; ++x){
                                 if(tests[j].getName().equals(test[x].getName()))
                                     break;
                             }
                             test[x].setBegin(count1);
                             tests[j].setHrr();
                             test[x].setHrr();
                             count = count1;
                         }
                         else{
                             count = tests[j].getBegin();
                         }
                     }
                 }

                 temp += tests[0].getName()+"   ";

                 //改变执行过的进程数据,使再次排序时排在未执行数据的后面
                 tests[0].setArrive(999999999);
                 tests[0].setBegin(999999999);
                 tests[0].setHrr(-1.0);

                 Arrays.sort(tests);    //重新排序

             }

             System.out.println("\n所以最后最高响应比调度算法执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);
         }

     }

     //RR类...............................................................
     public static class RR{

         private int count;
         private String temp;

         public RR(MyProcess test[]){

             count = 0;
             temp = "";

             int length = test.length;

             int wait = 0;    //总等待时间
             int cycle = 0;    //总周转时间

             int tur = 1;    //第几趟

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.println("轮转法调度算法的结果为:");
             System.out.println("第"+tur+"趟结果\n进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t剩余所需服务时间\t"
                     + "等待时间\t周转时间\t带权周转时间\t");

             int tempCount=0;    //记录是否还有进程未执行完

             int i=0;

             while(true){

                 if(test[i].getRwork()>timeSlice){

                     test[i].setRwork(test[i].getRwork()-timeSlice);

                     System.out.println(test[i].getName()+"\t"
                             +test[i].getArrive()+"\t"
                             +test[i].getWork()+"\t"
                             +count+"\t"
                             +(count+timeSlice)+"\t"
                             +test[i].getRwork()+"\t\t"
                             +"未执行完\t"
                             +"未执行完\t"
                             +"未执行完\t"
                             );

                     count += timeSlice;
                     temp += test[i].getName()+"  ";

                     ++i;
                     if(i==length){
                         i=0;
                         ++tur;
                         System.out.println("第"+tur+"趟结果\n进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t"
                                 + "剩余所需服务时间\t等待时间\t周转时间\t带权周转时间\t");
                     }
                 }

                 else if(test[i].getRwork()>0){

                     System.out.println(test[i].getName()+"\t"
                             +test[i].getArrive()+"\t"
                             +test[i].getWork()+"\t"
                             +count+"\t"
                             +(count+test[i].getRwork())+"\t"
                             +"0\t\t"
                             +(count+test[i].getRwork()-test[i].getWork()-test[i].getArrive())+"\t"
                             +(count+test[i].getRwork()-test[i].getArrive())+"\t"
                             +(count+test[i].getRwork()-test[i].getArrive())*1.0/test[i].getWork()+"\t"
                             );

                     wait += count+test[i].getRwork()-test[i].getWork()-test[i].getArrive();
                     cycle += count+test[i].getRwork()-test[i].getArrive();

                     count += test[i].getRwork();
                     temp += test[i].getName()+"  ";

                     test[i].setRwork(0);

                     ++i;
                     if(i==length){
                         i=0;
                         ++tur;
                         System.out.println("第"+tur+"趟结果\n进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t"
                                 + "剩余所需服务时间\t等待时间\t周转时间\t带权周转时间\t");
                     }

                     ++tempCount;
                     if(tempCount == length)
                         break;
                 }
                 else{
                     ++i;
                     if(i==length){
                         i=0;
                         ++tur;
                         System.out.println("第"+tur+"趟结果\n进程名字\t到达时间\t服务时间\t开始时间\t结束时间\t"
                                 + "剩余所需服务时间\t等待时间\t周转时间\t带权周转时间\t");
                     }
                     continue;
                 }
             }

             System.out.println("\n所以最后轮转法调度算法执行的顺序为:" + temp);
             System.out.println("平均等待时间为:" + wait*1.0/length + ",平均周转时间为:" + cycle*1.0/length);
         }

     }    

     //主函数................................................................
     public static void main(String[] args) {
         Scanner input = new Scanner(System.in);

         while(true){
             int n;    //进程数
             while(true){
                 try{
                     System.out.print("输入进程个数:");
                     n = input.nextInt();
                     break;
                 } catch(Exception e){
                     System.out.println("输入不合法,请重新输入!");
                     input.nextLine();
                 }
             }
             MyProcess test[] = new MyProcess[n];    //进程数组
             MyProcess tests[] = new MyProcess[n];    //临时进程数组(HRR用)

             System.out.println("您想执行何种操作:");
             System.out.println("1.FCFS(先到先服务调度算法)");
             System.out.println("2.SJF(最短作业优先调度算法,非抢占式)");
             System.out.println("3.PSA(优先级调度算法)");
             System.out.println("4.RR(轮转法调度算法)");
             System.out.println("5.HRR(最高响应比调度算法)");
             System.out.println("6.SJF(最短作业优先调度算法,抢占式)");
             System.out.println("7.退出");
             int which;

             try{
                 which = input.nextInt();
             } catch(Exception e){
                 System.out.println("输入不合法,请重新输入!");
                 input.nextLine();
                 continue;
             }

             //FCFS
             if(which == 1){
                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的到达时间和服务时间:");
                     test[i].setArrive(input.nextInt());
                     test[i].setWork(input.nextInt());
                 }
                 whichComp = "FCFS";
                 new FCFS(test);
             }
             //SJF,非抢占式
             else if(which == 2){
                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的到达时间和服务时间:");
                     test[i].setArrive(input.nextInt());
                     test[i].setWork(input.nextInt());
                 }
                 whichComp = "SJF";
                 new SJF(test);
             }
             //PSA
             else if(which == 3){
                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的到达时间和服务时间和优先级:");
                     test[i].setArrive(input.nextInt());
                     test[i].setWork(input.nextInt());
                     test[i].setPriority(input.nextInt());
                 }
                 whichComp = "PSA";
                 new PSA(test);
             }
             //RR
             else if(which == 4){
                 System.out.print("请输入时间片的大小:");
                 timeSlice = input.nextInt();

                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的服务时间(剩余时间):");
                     test[i].setWork(input.nextInt());
                     test[i].setRwork(test[i].getWork());
                 }
                 whichComp = "RR";
                 new RR(test);
             }
             //HRR
             else if(which == 5){
                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     tests[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的到达时间和服务时间:");
                     int a = input.nextInt();
                     test[i].setArrive(a);
                     tests[i].setArrive(a);
                     int b = input.nextInt();
                     test[i].setWork(b);
                     tests[i].setWork(b);
                     //设置开始时间和响应比
                     test[i].setBegin(a);
                     test[i].setHrr();
                     tests[i].setBegin(a);
                     tests[i].setHrr();
                 }
                 whichComp = "HRR";
                 new HRR(test,tests);
             }
             //SJF,抢占式
             else if(which == 6){
                 for(int i=0; i<n; ++i){
                     test[i] = new MyProcess("P"+(i+1));
                     System.out.print("请输入P" + (i+1) + "的到达时间和服务时间:");
                     test[i].setArrive(input.nextInt());
                     test[i].setWork(input.nextInt());
                     test[i].setRwork(test[i].getWork());    //设置剩余时间
                 }
                 whichComp = "SJFS";
                 new SJFS(test);
             }
             else if(which == 7){
                 System.out.println("程序结束!");
                 break;
             }
             else {
                 System.out.println("输入不合法,请重新输入!");
             }

             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------");
             System.out.print("------------------------------------------------------------------");
             System.out.println("------------------------------------------------------------------\n\n");
         }

         input.close();

     }

 }

部分运行结果:

相同数据的最高响应比结果为

操作系统中的几种调度算法(JAVA版)的更多相关文章

  1. 南阳ACM 题目8:一种排序 Java版

    一种排序 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 现在有很多长方形,每一个长方形都有一个编号,这个编号可以重复:还知道这个长方形的宽和长,编号.长.宽都是整数:现 ...

  2. 剑指offer第二版面试题1:数组中重复的数字(JAVA版)

    题目:在一个长度为n的数组里的所有数字都在0到n-1的范围内.数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复的次数.请找出数组中任意一个重复的数字.例如如果输入长度为7的数组{ ...

  3. 剑指offer:1.找出数组中重复的数(java版)

    数组中重复的数:题目:找出数组中重复的数,题目描述:在一个长度为n的数组里的所有数字都在0到n-1的范围内.数组中某些数字是重复的,但不知道有几个数字是重复的.也不知道每个数字重复几次.请找出数组中任 ...

  4. 单例模式的几种实现-Java版

    目录 关键点 饿汉式 懒汉式 双检锁 静态内部类单例模式 枚举方式 关键点 私有化构造器 通过静态方法或枚举返回单例类对象 确保单例类对象只有一个,尤其在多线程环境下. 确保每个类被序列化不会重新创建 ...

  5. 剑指offer第二版面试题2:数组中重复的数字(JAVA版)

    题目:在一个长度为n+1的数组里的所有数字都在1~n的范围内,所以数组中至少有一个数字是重复的.请找出数组中任意一个重复的数字,但是不能修改输入的数组.例如,如果输入长度为8的数组{2,3,5,4,3 ...

  6. Java实现操作系统中四种动态内存分配算法:BF+NF+WF+FF

    1 概述 本文是利用Java实现操作系统中的四种动态内存分配方式 ,分别是: BF NF WF FF 分两部分,第一部分是介绍四种分配方式的概念以及例子,第二部分是代码实现以及讲解. 2 四种分配方式 ...

  7. c#中的23种设计模式

    C# 23种设计模式汇总 创建型模式 工厂方法(Factory Method) 在工厂方法模式中,工厂方法用来创建客户所需要的产品,同时还向客户隐藏了哪种具体产品类将被实例化这一细节.工厂方法模式的核 ...

  8. Oracle Berkeley DB Java 版

    Oracle Berkeley DB Java 版是一个开源的.可嵌入的事务存储引擎,是完全用 Java 编写的.它充分利用 Java 环境来简化开发和部署.Oracle Berkeley DB Ja ...

  9. 剑指Offer面试题15(Java版):链表中倒数第K个结点

    题目: 输入一个链表.输出该链表中倒数第k哥结点.  为了符合大多数人的习惯,本题从1開始计数.即链表的尾结点是倒数第1个结点. 比如一个链表有6个结点.从头结点開始它们的值依次是1.2.3,4,5, ...

随机推荐

  1. c# 字符串的内存分配和驻留池( 转 )

    刚开始学习C#的时候,就听说CLR对于String类有一种特别的内存管理机制:有时候,明明声明了两个String类的对象,但是他们偏偏却指向同一个实例.如下: string s1 = "he ...

  2. AssemblyExecuteAdapter

    BizTalk custom adapter AssemblyExecuteAdapter 功能 更为方便的扩展BizTalk custom adapter 的交互方式,只需要实现IAssemblyE ...

  3. IntelliJ IDEA sass环境配置及常见报错处理

    1.下载安装ruby,网上教程很多的,安装完之后在命令行输入ruby -v检查一下是否安装成功了.(注意安装的时候要勾选第二项).

  4. Vue.js和jQuery混合使用的一点注意事项

    首先,Vue 的官方是不建议直接操作 DOM 的,其优势在于视图和数据的双向绑定,而且所有DOM操作都可以用Vue实现,反而使用jQuery来操作DOM的话,会造成不必要的麻烦,DOM未渲染完成之前事 ...

  5. Python内置函数(59)——open

    英文文档: open(file, mode='r', buffering=-1, encoding=None, errors=None, newline=None, closefd=True, ope ...

  6. javascript实现浏览器窗口大小被改变时触发事件的方法

    转载 当浏览器的窗口大小被改变时触发的事件window.onresize 为事件指定代码: 复制代码代码如下: window.onresize = function(){ } 例如: 浏览器可见区域信 ...

  7. Linux入门:vi 和 vim

    vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器. 本文介绍了vi (vim)的基本使用方法,但对于普通用户来说基本上够了! 转自:http://www.l ...

  8. kubernetes进阶(05)kubernetes的命令

    在Kubernetes中,Node.Pod.Replication Controller.Service等概念都可以看作一种资源对象,通过Kubernetes提供的Kubectl工具或者API调用进行 ...

  9. 开发一个http代理服务器

    参考链接: http://www.cnblogs.com/jivi/archive/2013/03/10/2952860.html https://www.2cto.com/kf/201405/297 ...

  10. Angular UI框架 Ng-alain @delon的脚手架的生成开发模板

    前言 首先感谢下 cipchk基于 Ng-Zorror 框架上制作的ng-alain . 之前很早就关注了 ng-alain,今天得空折腾了下. 折腾的时候发现官方文档有些坑,没有写清楚,所以我作为一 ...