欧拉函数/欧拉函数打表 lightoj1370(java/c++ )

简介: Bamboo Pole-vault是Xzhiland的一项大受欢迎的运动。 Phi-shoe大师是他成功的非常受欢迎的教练。他需要为他的学生提供一些竹子,所以他让他的助手Bi-Shoe去市场购买。市场上有很多可能的整数长度的Bamboos(是的!)。根据Xzhila的传统,

题目



Bamboo Pole-vault是Xzhiland的一项大受欢迎的运动。 Phi-shoe大师是他成功的非常受欢迎的教练。他需要为他的学生提供一些竹子,所以他让他的助手Bi-Shoe去市场购买。市场上有很多可能的整数长度的Bamboos(是的!)。根据Xzhila的传统,


竹子的分数=Φ(竹子的长度)


(Xzhilans非常喜欢数论)。对于您的信息,Φ(n)=小于n的数字,它们相对于素数(除了1之外没有公约数)到n。因此,长度为9的竹子的得分为6,因为1,2,4,5,7,8是9的相对素数。


助理双鞋必须为每个学生买一个竹子。作为一个扭曲,Phi-shoe的每个撑杆跳学生都有一个幸运数字。 Bi-shoe希望购买竹子,这样他们每个人都会得到一张分数大于或等于他/她的幸运数字的竹子。 Bi-shoe希望最大限度地减少购买竹子所花费的总金额。一个竹子单位花费1 Xukha。帮助他


输入



输入以整数T(≤100)开始,表示测试用例的数量。


每个案例都以包含整数n(1≤n≤10000)的行开头,表示Phi-shoe的学生人数。下一行包含n个空格分隔的整数,表示学生的幸运数字。每个幸运数字将位于[1,106]范围内。


输出



对于每种情况,打印案例编号和购买竹子所花费的最少金额。有关详细信息,请参阅示例


Sample Input



3

5

1 2 3 4 5

6

10 11 12 13 14 15

2

1 1


Sample Output



Case 1: 22 Xukha

Case 2: 88 Xukha

Case 3: 4 Xukha


题意



题意:给你n个整数,第i个整数为Xi。定义phi(k)为k的欧拉函数值,设pi为满足phi(pi)>=Xi的最小整数,题目就是要求sum(p1,p2,p3,…,pn)。


告诉你幸运数字x,你找出phi(n)=x的这个最小的n,若干个这样数的合。


首先要清楚几个概念phi(n)=n-1,n为素数时候。因为n和小于它的任意都互质。

所以解题思路大致有两个:


欧拉函数的角度:


欧拉是最明显的,要找出大于这个数最小的那个phi[i],如果单个欧拉函数求会TL所以需要欧拉打表。没输入一个数网上找几个就行了


素数角度


n为素数时候,phi(n)=n-1,所以第一个phi(i)=t的那个i就是在t右侧的第一个素数。有了这个思路你就可以用素数解决问题,可以用素数筛。用直接的素数判定也能过。


c++代码:



直接判定


#include <iostream>
#include<stdio.h>
using namespace std;
#define ll long long
bool isprime(int index)
 {
    if(index<=2)return true;
    else {
      for(int i=2;i*i<index+1;i++)
      {
        if(index%i==0)return false;
      }
      return true;
    }
 }
int main()
{
       int t;cin>>t;
       for(int i=0;i<t;i++)
       {
         int n;cin>>n;ll count=0;
         for(int j=0;j<n;j++)
         {
           ll team;
           cin>>team;
           int index=team+1;
           while(!isprime(index))
                {index++;}
           count+=index;
         }
         //string s=" Xukha";
          printf("Case %d: %lld Xukha\n",(i+1),count);
       }
       return 0;
}


欧拉筛


#include <iostream>
#include<stdio.h>
using namespace std;
#define ll long long
const int MAXN=1100000+7;
int m;
ll a[MAXN],euler[MAXN];
void phi()
{
    for(int i=1;i<=m;i++)
    a[i]=i;
    for(int i=2;i<=m;i+=2)
    a[i]>>=1;
    for(int i=3;i<=m;i++)
    {
        if(a[i]==i)
        {
            for(int j=i;j<=m;j+=i)
            a[j]=(a[j]/i)*(i-1);
        }
    }
}
int main()
{
         m=1100000;
         phi();
       int t;cin>>t;
       for(int i=0;i<t;i++)
       {
           ll n,count;
         cin>>n;count=0;
         for(int j=0;j<n;j++)
         {
           ll team;
           cin>>team;
           int index=team+1;
           while(a[index]<team)
                {index++;}
           count+=index;
         }
          printf("Case %d: %lld Xukha\n",(i+1),count);
       }
       return 0;
}


java 欧拉打表(可以自己改成素数)


import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.StreamTokenizer;
import java.util.Scanner;
public class Main{
  public static void main(String[] args) throws IOException {
    // TODO 自动生成的方法存根
    StreamTokenizer in=new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
    PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));
       in.nextToken();int t=(int)in.nval;
       int a[]=new int[1100001];
       for(int i=1;i<1100001;i++)
       {
         a[i]=i;
       }
       for(int i=2;i+2<1100001;i+=2)
       {
         a[i]/=2;
       }
       for(int i=3;i+2<1100001;i+=2)
       {
         if(a[i]==i)
         {
           for(int j=i;j+i<=1100001;j+=i)
           {
             a[j]=a[j]/i*(i-1);
           }
         }
       }
       for(int i=0;i<t;i++)
       {
         in.nextToken();int n=(int)in.nval;long count=0;
         for(int j=0;j<n;j++)
         {
           in.nextToken();
           long team=(long)in.nval;
           int index=(int) (team+1);
           while(a[index]<team) {index++;}
           count+=index;
           //System.out.println(oula(team));
         }
         System.out.println("Case "+(i+1)+": "+count+" Xukha");
       }
  }
  private static boolean isprime(int index) {
    if(index<=2)return true;
    else {
      for(int i=2;i*i<index+1;i++)
      {
        if(index%i==0)return false;
      }
      return true;
    }
  }
  private static int oula(int team) {
    int i=0;int res=team;int team1=team;
    for(i=2;i<(int)Math.sqrt(team1)+1;i++)
    {
      if(team%i==0) {
        res=res/i*(i-1);
        while(team%i==0) {team/=i;}//保证I是素数       
      }
    }
    if(team>1)res=res/team*(team-1);
    return res;
  }
}

2019052321535994.png


目录
相关文章
|
15天前
|
Java Android开发 C++
Java和C++
Java和C++
33 15
WK
|
1月前
|
安全 Java 编译器
C++和Java哪个更好用
C++和Java各具优势,选择取决于项目需求、开发者偏好及目标平台特性。C++性能出色,适合游戏、实时系统等;Java平台独立性强,适合跨平台、安全敏感应用。C++提供硬件访问和灵活编程范式,Java有自动内存管理和丰富库支持。两者各有千秋,需根据具体需求选择。
WK
30 1
|
2月前
|
IDE Java 程序员
C++ 程序员的 Java 指南
一个 C++ 程序员自己总结的 Java 学习中应该注意的点。
25 5
|
2月前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
2月前
|
Java
让星星⭐月亮告诉你,jdk1.8 Java函数式编程示例:Lambda函数/方法引用/4种内建函数式接口(功能性-/消费型/供给型/断言型)
本示例展示了Java中函数式接口的使用,包括自定义和内置的函数式接口。通过方法引用,实现对字符串操作如转换大写、数值转换等,并演示了Function、Consumer、Supplier及Predicate四种主要内置函数式接口的应用。
30 1
|
2月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
79 6
|
2月前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
30 3
WK
|
1月前
|
开发框架 移动开发 Java
C++和Java哪个更适合开发移动应用
本文对比了C++和Java在移动应用开发中的优劣,从市场需求、学习难度、开发效率、跨平台性和应用领域等方面进行了详细分析。Java在Android开发中占据优势,而C++则适合对性能要求较高的场景。选择应根据具体需求和个人偏好综合考虑。
WK
55 0
|
2月前
|
C++
C++ 多线程之线程管理函数
这篇文章介绍了C++中多线程编程的几个关键函数,包括获取线程ID的`get_id()`,延时函数`sleep_for()`,线程让步函数`yield()`,以及阻塞线程直到指定时间的`sleep_until()`。
37 0
C++ 多线程之线程管理函数
WK
|
1月前
|
安全 Java 编译器
C++和Java哪个更适合开发web网站
在Web开发领域,C++和Java各具优势。C++以其高性能、低级控制和跨平台性著称,适用于需要高吞吐量和低延迟的场景,如实时交易系统和在线游戏服务器。Java则凭借其跨平台性、丰富的生态系统和强大的安全性,广泛应用于企业级Web开发,如企业管理系统和电子商务平台。选择时需根据项目需求和技术储备综合考虑。
WK
84 0
下一篇
DataWorks