• ural 1818 Fair Fishermen


    题意:

      有n个人分鱼,第一个人先来拿,检查一下总数,如果不能恰好分成n份,则扔掉多余的部分,然后拿走自己应得的1/n,第二个人也重复这个步骤,直到第n个人,然后告诉你每次扔掉鱼的数量,求一开始最少有多少鱼。

    方法:

      对于例子

      4

      1 1 1 2

      假设第三个人拿完以后的状态是还有X条鱼,设X = A[n]+K = 2+K,那么要满足X%(N-1)==0,且K的出现不会影响多余鱼的条数,也就是说,把这个K单独当成一部分,它可以正好分给n个人1次,那我们现在要找到这个最小的K,易知最小的K就是N*(N-1-A[N]%(N-1)),这样我们就推出了X,带入得X=6。

      则第三个人拿之前的个数就是Y = X/(N-1)*N+a[3],设Z是第二个人拿完之后的条数,假设Z = Y + K2,和上一次要求一样,则K2=N^2*(N-1-Y%(N-1)),系数是N^2,这样可以保证它下面2层都正好足够分给N个人,且不可能存在比这个更小的满足条件的系数。

      其实还是有点小混乱,先记录下来,回头脑袋清醒了再来研究一番~

    代码:

     1 import java.math.BigInteger;
     2 import java.util.Scanner;
     3 
     4 public class Main{
     5     static int[]a = new int[2013];
     6     public static BigInteger V(int v){
     7         return BigInteger.valueOf(v);
     8     }
     9     public static void main(String[] args){
    10         Scanner cin = new Scanner(System.in);
    11         int n = cin.nextInt();
    12         for(int i=0;i<n;i++){
    13             a[i] = cin.nextInt();
    14         }
    15         BigInteger ans=V(a[n-1]),now=V(n),mod=V(n-1);
    16         for(int i = n-2;i >= 0;i--){
    17             int dif = ans.mod(mod).intValue();
    18             if(dif!=0) dif = n-1-dif;
    19             ans = ans.add(now.multiply(V(dif))).divide(mod).multiply(V(n)).add(V(a[i]));
    20             System.out.println(ans);
    21             now = now.multiply(V(n));
    22         }
    23         if(ans.equals(V(0))) ans = now;
    24         System.out.println(ans);
    25     }
    26 }
    ural 1818

      

  • 相关阅读:
    07-2. A+B和C (15)
    07-1. 换个格式输出整数 (15)
    07-0. 写出这个数 (20)
    06-3. 单词长度(15)
    06-2. 字符串字母大小写转换(10)
    06-1. 简单计算器(20)
    06-0. 混合类型数据格式化输入(5)
    05-3. 求a的连续和(15)
    05-2. 念数字(15)
    05-1. 约分最简分式(15)
  • 原文地址:https://www.cnblogs.com/SolarWings/p/3439545.html
Copyright © 2020-2023  润新知