SDUT中大数实现的题目,持续更新(JAVA实现)

SDUT2525:A-B (模板题)

复制代码
import java.util.Scanner;
import java.math.*;

public class Main
{

    public static void main(String[] args)
    {
        Scanner ci = new Scanner(System.in);
        BigInteger a;
        BigInteger b;
        while(ci.hasNext())
        {
            a=ci.nextBigInteger();
            b=ci.nextBigInteger();
            System.out.println(a.subtract(b));
        }
        ci.close();
    }

}
复制代码

SDUT3134:大数取模

复制代码
import java.util.Scanner;
import java.math.*;

public class Main
{
    public static void main(String[] args)
    {
        Scanner cin = new Scanner(System.in);
        while(cin.hasNext())
        {
            BigInteger a,b;
            a=cin.nextBigInteger();
            b=cin.nextBigInteger();
            System.out.println(a.mod(b));
            
        }
        cin.close();
    }

}
 
View Code
复制代码

SDUT2613:大数加法

复制代码
import java.util.Scanner;
import java.math.*;

public class Main
{
    public static void main(String[] args)
    {
        Scanner cin = new Scanner(System.in);
        while(cin.hasNext())
        {
            BigInteger a,b;
            a=cin.nextBigInteger();
            b=cin.nextBigInteger();
            System.out.println(a.add(b));
            
        }
        cin.close();
    }

}
 
View Code
复制代码

SDUT2763: 好玩的五次方

这个题还是比较好的,利用了math中的pow方法,属于大数乘法

复制代码
import java.util.Arrays;
import java.util.Scanner;
import java.math.*;

public class Main
{
    public static void main(String[] args)
    {
        Scanner cin = new Scanner(System.in);
        int n,t,cnt,ff;
        while(cin.hasNext())
        {
            n=cin.nextInt();
            cnt=0;
            ff=-1;
            int[] a=new int[n];
            int[] b=new int[n];
            for(int i=0;i<n;i++)
            {
              a[i]=cin.nextInt();
            }
            Arrays.sort(a);
            for(int i=0;i<n;i++)
            {
                if(a[i]>0)
                    b[cnt++]=a[i];
            }
            for(int i=0;i<cnt;i++)
            {
                if(b[i]!=(i+1))
                {
                    ff=i+1;
                    break;
                }
            }
            if(ff==-1) ff=cnt+1;
            BigInteger sum=BigInteger.valueOf(ff);
            System.out.println(sum.pow(5));
            
        }
        cin.close();
    }

}
 
复制代码

 

posted @   人艰不拆_zmc  阅读(174)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 张高兴的大模型开发实战:(一)使用 Selenium 进行网页爬虫
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示