java学习基础:Math类

记录学习java路程将与风雨相伴!!!

Math类(数学类)

算术计算

Math.sqrt():计算平方根

Math.cbrt():计算立方根

Math.pow(a,b):计算a的b次方

Math.max(,):计算最大值

Math.min(,):计算最小值

Math.abs():取绝对值

进位

Math.ceil():天花板的意思,就是逢余进一

Math.floor():地板的意思,就是逢余舍一

Math.rint():四舍五入,返回double值。注意.5的时候会取偶数

Math.round():四舍五入,float时返回int值,double时返回long值

public class MathDemo{
	public static void main(String argsu){
		 /**
		*abs求绝对值
		*/
		System.out.printin(Math.abs(-10.4);//10.4
		System.out.printin(Math.abs(10.1);//10.1
		/**
		*ceil天花板的意思,就是返回大的值,注意一些特殊值
		*/
		System.out.printin(Math.ceil(-10.1));//-10.0
		System.out.printin(Math.ceil(10.7);//11.0
		System.out.printin(Math.ceil(-0.7);//-0.0
		System.out.printin(Math.ceil(0.0);//0.0
		System.out.printin(Math.ceil(-0.0);//-0.0

       		 /**
       		 *floor地板的意思,就是返回小的值
       		 */
        	System.out.printin(Math.floor(-10.1);//-11.0
        	System.out.printin(Math.floor(10.7));//10.0
        	System.out.printin(Math.floor(-0.7);//-1.0
        	System.out.printin(Math.floor(0.0);//0.0
        	System.out.printin(Math.floor(-0.0);//-0.0
        	/**
        	*max两个中返回大的值,min和它相反,就不举例了
        	*/
        	System.out.printin(Math.max(-10.1-10));//-10.0
        	System.out.printin(Math.max(10.710);//10.7
        	System.out.println(Math.max(0.0-0.0));//0.0
        	/**
        	*random取得一个大于或者等于0.0小于不等于1.0的随数
	        */
	        System.out.printin(Math.random0);
	        //0.08417657924
	        System.out.printin(Math.randomO);
	        //0.43527904004

	        /**
	        *rint 四含五入,返回double值
	        *注意5的时候会取偶数
	        */
	        System.out.println(Math.rint(10.1);/10.0
	        System.out.printin(Math.rint(10.7);//11.0
	        System.out.printin(Math.rint(11.5);//12.0
	        System.out.printin(Math.rint(10.5);//10.0
	        System.out.println(Math.rint(10.51));//11.0
	        System.out.printin(Math.rint(-10.5));//-10.0
	        System.out.printin(Math.rint(-11.5);//-12.0
	        System.out.printin(Math.rint(-10.51));//-11.0
	        System.out.println(Math.rint(-10.6);//-11.0
	        System.out.printin(Math.rint(-10.2));//-10.0
	
	        /**
	        *round 四舍五入,float时返回int值,double时返回long值
	        */
	        System.out.printin(Math.round(10.1);//10
	        System.out.println(Math.round(10.7);//11
	        System.out.printin(Math.round(10.5);//11
	        System.out.printin(Math.round(10.51));//11
	        System.out.printin(Math.round(-10.5);//-10
	        System.out.printin(Math.round(-10.51));//-11
	        System.out.println(Math.round(-10.6))://-11
	        System.out.printin(Math.round(-10.2);//-10
	        }
	}

随机数

Math.random():取得一个[0,1)范围内的随机数

/**Math中,随机数的代码是:random.

也就是 Math.random();

这时一个 返回的是[0,1)double类型的值

是一个伪随机数

伪随机数就是按照一定规则去随机的数

当需要打印多少范围到多少范围直接的随机整数时,会运用到一条公式

公式: (最大值 - 最小值 +1 ) + 最小值 **/

例如:

 //打印[5-10]的随机整数   

 int num = (int)(Math.random() * 6 + 5);  

  //random本是double类型的,如果想打印整数类型(int)就需要将它强制转换成int类型  

  //这里的步骤 就是强制转换     

   //这里的* 6 + 5  是由 (10 - 5 + 1) + 5 这么来的 

   //也就是套用公式       

 System.out.println(num);//需求:随机20个[10-300]之间的数 打印最大值		int max = 0;	for (int i = 0; i < 20; i++) {int num =(int) (Math.random()*291 + 10);if (max < num) {	

​			max = num;}		

}	

​	System.out.println(max);

热门文章

暂无图片
编程学习 ·

javascript 实现所有浏览器异步加载的工具

javascript 实现所有浏览器异步加载的工具 //异步加载 实现 function loadScript(url, callback){ //新建一个script 元素 var script = document.createElement(‘script’); //再往script中添加类型 script.type=“text/javascript”; if(script.readyState){ //每当 rea…
暂无图片
编程学习 ·

spring注解式开发

一、@Configuration 声明一个类相当于配置类似于xml的配置文件,声明一个或者多个@Bean方法,并由spring容器管理,以便于在运行中为这些bean生成BeanDefinition和服务请求。 @Configuration //包扫描 @ComponentScan(value = "com.alibaba") }) public class MyConf…
暂无图片
编程学习 ·

Spring Boot / Spirng Cloud 引入Rabbit MQ

注意: spring cloud版本:Greenwich.RELEASE spring boot 版本: 2.1.5.RELEASE 1.导包,在pom.xml中导入<dependency><groupId>org.springframework.amqp</groupId><artifactId>spring-rabbit</artifactId></dependency>2.加入配置文件 …
暂无图片
编程学习 ·

vue中的keep-alive使用总结

在平常开发中,有些组件只需要加载一次,后面的数据将不存在变化,亦或者是组件需要缓存状态,滚动条位置等,这个时候,keep-alive的用处就立刻凸显出来了。1.App.vue中使用keep-alive,include表示需要缓存的页面,exclude表示不需要缓存的页面,你可以只设置其中一个即可,但…
暂无图片
中恒嘉业 ·

Heap Sort 讲解

Heap Sort sorts a group of unordered elements using the Heap data structure. The sorting algorithm using a Min Heap is as follows: Heapify all elements into a Min HeapRecord and delete the top elementPut to top element into an array T that stores all so
暂无图片
cgfy ·

8. 源码分析之ConsumeQueue

源码分析之ConsumeQueue 消息发送时数据在ConsumeQueue的落地 ​ 连续发送5条消息&#xff0c;消息是不定长&#xff0c;首先所有信息先放入 Commitlog中&#xff0c;每一条消息放入Commitlog的时候都需要上锁&#xff0c;确保顺序的写入。 ​ 当Commitlog写成功了之后。数据…
暂无图片
coreui ·

Heap Sort 讲解

Heap Sort sorts a group of unordered elements using the Heap data structure. The sorting algorithm using a Min Heap is as follows: Heapify all elements into a Min HeapRecord and delete the top elementPut to top element into an array T that stores all so
暂无图片
coreui ·

[react] 你觉得react上手快不快?它有哪些限制?

[react] 你觉得react上手快不快&#xff1f;它有哪些限制&#xff1f; 相对vue来说不快。 限制 需要学习JSX需要工程化的配置需要对原生JavaScript有相当的掌握react只是一个UI层面的库&#xff0c;像vue内置了动画处理、keep-alive等功能&#xff0c;react则需要去找第三方库…
暂无图片
未来博客 ·

Heap Sort 讲解

Heap Sort sorts a group of unordered elements using the Heap data structure. The sorting algorithm using a Min Heap is as follows: Heapify all elements into a Min HeapRecord and delete the top elementPut to top element into an array T that stores all so
暂无图片
未来博客 ·

[react] 你觉得react上手快不快?它有哪些限制?

[react] 你觉得react上手快不快&#xff1f;它有哪些限制&#xff1f; 相对vue来说不快。 限制 需要学习JSX需要工程化的配置需要对原生JavaScript有相当的掌握react只是一个UI层面的库&#xff0c;像vue内置了动画处理、keep-alive等功能&#xff0c;react则需要去找第三方库…
暂无图片
建站日记 ·

[react] 你觉得react上手快不快?它有哪些限制?

[react] 你觉得react上手快不快&#xff1f;它有哪些限制&#xff1f; 相对vue来说不快。 限制 需要学习JSX需要工程化的配置需要对原生JavaScript有相当的掌握react只是一个UI层面的库&#xff0c;像vue内置了动画处理、keep-alive等功能&#xff0c;react则需要去找第三方库…
暂无图片
mfbz ·

AOV网是否存在回路-拓扑排序-C++

拓扑排序是对测试AOV网是否存在回路的方法&#xff01; 拓扑排序的过程中&#xff0c;由于需要查找所有以某顶点为尾的弧&#xff0c;即找到该顶点的所有出边&#xff0c;故图要采用邻接表的存储方式。但拓扑排序较邻接表的存储方式有一点不同&#xff0c;由于要查找入度为0的点…
暂无图片
mfbz ·

[react] 你觉得react上手快不快?它有哪些限制?

[react] 你觉得react上手快不快&#xff1f;它有哪些限制&#xff1f; 相对vue来说不快。 限制 需要学习JSX需要工程化的配置需要对原生JavaScript有相当的掌握react只是一个UI层面的库&#xff0c;像vue内置了动画处理、keep-alive等功能&#xff0c;react则需要去找第三方库…
暂无图片
珊珊日记 ·

AOV网是否存在回路-拓扑排序-C++

拓扑排序是对测试AOV网是否存在回路的方法&#xff01; 拓扑排序的过程中&#xff0c;由于需要查找所有以某顶点为尾的弧&#xff0c;即找到该顶点的所有出边&#xff0c;故图要采用邻接表的存储方式。但拓扑排序较邻接表的存储方式有一点不同&#xff0c;由于要查找入度为0的点…
暂无图片
珊珊日记 ·

8. 源码分析之ConsumeQueue

源码分析之ConsumeQueue 消息发送时数据在ConsumeQueue的落地 ​ 连续发送5条消息&#xff0c;消息是不定长&#xff0c;首先所有信息先放入 Commitlog中&#xff0c;每一条消息放入Commitlog的时候都需要上锁&#xff0c;确保顺序的写入。 ​ 当Commitlog写成功了之后。数据…