两个算法--Day2



package algorithm;
/*
 * 1.输入一个数,判断该数是否为素数?如果是输出yes,否则输出no
 * 2.现在有一个整数数组,已知一个数出现的次数超过了一半,请用O(n)的复杂度的算法找出这个数。
 */
import java.io.*;
import java.util.*;
public class Day2 {

 public static void main(String[] args) throws Exception{
  // TODO Auto-generated method stub
  //Sushu ss=new Sushu();
  //ss.panduan();
  Shuzu sz=new Shuzu();
  int []arr={1,2,4,2,3,42,2,2,2,6,7,2,2,2,2,2};
  sz.chazhao(arr);
  
 }

}

class Sushu
{
 int num;
 public void panduan ()throws Exception
 {
  while(true)
  {
   System.out.println("请输入一个正整数(按0退出):");
   InputStreamReader isr=new InputStreamReader(System.in);
   BufferedReader br=new BufferedReader(isr);
   this.num=Integer.parseInt(br.readLine());
   
   if(num==0)
   {
    System.out.println("退出");
    break;
   }else if(num<0)
   {
    System.out.println("请重新输入");
    continue;
   }else{
    this.sushu(this.num);
   }
  }
 }
 
 
 public void sushu(int num)
 {
  int a,b;
  int i;
  int j=0;
  
  if(num==1)
  {
   System.out.println("No");
  }
  else
  {
   for(i=2;i<num;i++)
   {
    
    a=num%i;
    b=num/i;
    if(a==0&&b!=num&&b!=1)
    {
     System.out.println("No");
     j=1;
     break;
    }
   }
   if(j==0)
   {
    System.out.println("Yes");
   }
  }
 
 }
}
class Shuzu
{
  public void chazhao(int arr[])
  {
   int j;
   HashMap<Integer,Integer> hm=new HashMap<Integer,Integer>();
   for (int i=0;i<arr.length;i++) 
   {
    if (hm.containsKey(arr[i]))
    {
     j=hm.get(arr[i])+1;
     if(j>arr.length/2)
     {
      System.out.println("结果是:"+arr[i]);
      break;
     }
     hm.put(arr[i], j);
    }else{
     hm.put(arr[i],1);
    }
    
   }
  }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现自动排班算法的一种方法是使用贪心算法。具体步骤如下: 1. 创建一个长度为21的数组,表示21个人的编号。 2. 创建一个长度为21的布尔型数组,表示每个人是否已经被安排了排班。 3. 创建一个长度为14的二维数组,表示14天的排班情况。数组的每个元素为一个长度为2的数组,表示当天安排的两个人的编号。 4. 对于每一天,随机选择两个未被安排过的人,并将他们的编号存入当天的排班数组中。 5. 将这两个人标记为已经被安排过排班。 6. 重复步骤4-5,直到所有的天数都被安排了排班。 具体的Java代码实现如下: ```java public class Schedule { private static final int NUM_PEOPLE = 21; private static final int NUM_DAYS = 14; public static void main(String[] args) { int[] people = new int[NUM_PEOPLE]; for (int i = 0; i < NUM_PEOPLE; i++) { people[i] = i + 1; } boolean[] scheduled = new boolean[NUM_PEOPLE]; int[][] schedule = new int[NUM_DAYS][2]; Random random = new Random(); for (int i = 0; i < NUM_DAYS; i++) { int[] today = new int[2]; int count = 0; while (count < 2) { int index = random.nextInt(NUM_PEOPLE); if (!scheduled[index]) { today[count] = people[index]; scheduled[index] = true; count++; } } schedule[i] = today; } // 输出排班结果 for (int i = 0; i < NUM_DAYS; i++) { System.out.println("Day " + (i + 1) + ": " + schedule[i][0] + ", " + schedule[i][1]); } } } ``` 这个实现中使用了Java内置的随机数生成器来随机选择未被安排过的人。这个算法的时间复杂度为$O(N\times D)$,其中$N$为人数,$D$为天数。这个算法的效率比较高,但是可能会出现一些特殊情况,例如某个人在某一天被安排了排班,但是在后面的排班中没有被安排,这种情况下可能需要手动调整排班。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值