java除以一个数,能整除直接取商,如不能整除则只取整数部分,记得api里有方法能直接实现,哪位请告知?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java除以一个数,能整除直接取商,如不能整除则只取整数部分,记得api里有方法能直接实现,哪位请告知?相关的知识,希望对你有一定的参考价值。

也就是1000除以10,取100;997除以10取99。记得好像有个取余的api,哪位知道麻烦告诉下。谢谢。

int cc = (int)Math.ceil(998/10);//向下

int cc = (int)Math.floor(997/10);//向上 

Java由四方面组成:

1.Java编程语言,即语法。

2.Java文件格式,即各种文件夹、文件的后缀。

3.Java虚拟机(JVM),即处理*.class文件的解释器。

4.Java应用程序接口(Java API)。

Java分为三个体系:

1.Java SE(J2SE,Java2 Platform Standard Edition,标准版),

2.JavaEE(J2EE,Java 2 Platform, Enterprise Edition,企业版),

3.Java ME(J2ME,Java 2 Platform Micro Edition,微型版)。

参考技术A public class TestMath 

public static void main(String[] args) 
double x = 2;
double y = 1;
//向上取整
double m = Math.ceil(y/x);
//向下取整
double n = Math.floor(y/x);
System.out.println("向上取整"+m+"\\n向下取整"+n);
//注意int/int结果是int,所以要把997变成997.0 变成double类型才能取值
System.out.println(Math.ceil(997.0/10));


参考技术B 你用int来接受就是鸟;int i=997/10;追问

我问题描述错了。应该是如果不能整除,向上取值,如997/10取100,而不是99。记得好像有个api能直接用。

追答

int cc = (int)Math.ceil(998/10);//向下
int cc = (int)Math.floor(997/10);//向上

本回答被提问者采纳

leetCode(49):Count Primes

Description:

Count the number of prime numbers less than a non-negative number, n.

推断一个数是否是质数主要有下面几种方法:

1)直接用该数除于全部小于它的数(非0。1),假设均不能被它整除,则其是质数。

2)除以小于它一半的数。由于大于其一半必然是无法整除。假设均不能被它整除。则其是质数;

3)除以小于sqrt(a)的数,原因例如以下:

        除了sqrt(a)之外,其它的两数乘积为a的,一定是比个比sqrt(a)小,一个比sqrt(a)大。所以推断到sqrt(a)就能够了,由于还有一半就是刚才做除法的商的那部份。

4)除以小于sqrt(a)的质数就可以。

        由于质数不能被除自身和1外的全部数整除。非质数则不然,且其必定能被某一质数整除。假设一个数能被某一非质数整除。则其必定能被组成这一非质数的最小质数整数。

          从上能够看出,推断一个数是否是质数。其计算量取决于整除的个数。上述四种方法,除数逐渐变少。


通过以上分析,这是本人自己的程序:

class Solution {
public:
    int countPrimes(int n) {
        if (n == 0 || n == 1 || n==2)
    		return 0;
    
    	vector<int> vec;//质数容器
    
    	vec.push_back(2);
    	for (int i = 3; i < n; ++i)
    	{
    		int j = 0;
    		int length=vec.size();
    		for (; j<length && vec[j]*vec[j]<i; ++j)//除数是小于sqrt(i)的全部质数
    		{
    			if (i%vec[j] == 0)
    				break;
    		}
    		if (vec[j]*vec[j]>i)
    			vec.push_back(i);
    	}
    	return vec.size();
    }
};

以下是在网上找到一个程序,非常具体:

这道题给定一个非负数n,让我们求小于n的质数的个数,题目中给了充足的提示。解题方法就在第二个提示埃拉托斯特尼筛法Sieve of Eratosthenes中。这个算法的步骤例如以下图所看到的,我们从2開始遍历到根号n,先找到第一个质数2,然后将其全部的倍数全部标记出来。然后到下一个质数3。标记其全部倍数。一次类推,直到根号n,此时数组中未被标记的数字就是质数。我们须要一个n-1长度的bool型数组来记录每一个数字是否被标记,长度为n-1的原因是题目说是小于n的质数个数。并不包含n。

然后我们用两个for循环来实现埃拉托斯特尼筛法,难度并非非常大。代码例如以下所看到的:

 

技术分享

 

技术分享
class Solution {
public:
    int countPrimes(int n) {
        vector<bool> num(n - 1, true);
        num[0] = false;
        int res = 0, limit = sqrt(n);
        for (int i = 2; i <= limit; ++i) {
            if (num[i - 1]) {
                for (int j = i * i; j < n; j += i) {//为什么要从i*i開始,由于小于i*i的数可能已经被小于i的数整除了。假设没有,那它就是质数
                    num[j - 1] = false;
                }
            }
        }
        for (int j = 0; j < n - 1; ++j) {
            if (num[j]) ++res;
        }
        return res;
    }
};
技术分享






以上是关于java除以一个数,能整除直接取商,如不能整除则只取整数部分,记得api里有方法能直接实现,哪位请告知?的主要内容,如果未能解决你的问题,请参考以下文章

滴滴笔试

中国剩余定理(转)

js中如何判断两个数是不是整除

剑指offer——丑数(c++)

判断一个数能否同时被4和5整除

js中如何判断两个数是不是整除?