- 二叉树遍历
二叉树遍历非递归实现目录二叉树遍历非递归实现树节点定义:先序遍历:中序遍历:后序遍历:测试代码:先序遍历测试代码:中序遍历测试代码:后序遍历测试代码:树节点定义:publicclassTreeNode{intval;TreeNodeleft;TreeNoderight;TreeNode(){}TreeNode(intval){this.val=val;}TreeNode(intval,TreeNo
- 前端项目3-02:登录页面
航Hang*
webstorm前端项目前端csscss3htmlhtml5
一、效果图二、全部代码码农魔盒body{background:linear-gradient(toright,#65CBF7,#B3A5FC);width:100vw;height:100vh;margin:0;}.box{width:60%;height:450px;box-shadow:05px15pxrgba(0,0,0,.8);display:flex;position:fixed;top
- 2105、给植物浇水II
椎名ひる
leetcode#相向双指针算法leetcode数据结构
题目:解答:这题有一个前提:每一株植物都是可以用对应的装满水的水壶完成浇水的。不然会陷入死循环(也就是不存在比如a需要浇水10,但是水壶容量只有8)思路:遇到植物先判断是否浇水,不够就灌水然后ans++,两边同时判断当left=right意味着二人相遇了,要浇水的植物一共为奇数个。这里不需要判断谁浇水,只要判断水最多的人够不够浇水即可。如果不够,直接ans++然后return。如果植物是偶数个,那
- 3、无重复字符的最长子串
椎名ひる
#滑动窗口leetcodeleetcode算法
题目:解答:划窗。创建哈希表来存储字母出现个数。两个指针left、right来表示窗口前后边界。遍历右指针,每次将右指针的字符对应的哈希表value++。然后判断该key的value是否大于1,如果大于1意味着有重复字符了,将左指针右移弹出一个字符,该字符的value--,重复这个步骤直到right指向的字符的value为1,即是该right边界的最大可能字符串。然后更新ans,ans=max(a
- 2958、最多K个重复元素的最长子数组
椎名ひる
#滑动窗口leetcodeleetcode算法数据结构
题目:解答:在上一题的基础上,修改一下即可。上一题是哈希表的value与1相比,本题改成与k相比即可。classSolution{public:intmaxSubarrayLength(vector&nums,intk){unordered_mapcnt;intleft=0,right=0;intlen=nums.size();intans=0;for(right;rightk){cnt[nums
- 二叉树题解——将有序数组转换为二叉搜索树【LeetCode】传统解法
潮_
我的学习记录二叉树篇_刷题笔记算法leetcode数据结构python
108.将有序数组转换为二叉搜索树方法一:中序遍历,总是选择中间位置左边的数字作为根节点选择中间位置左边的数字作为根节点,则根节点的下标为mid=(left+right)/2,此处的除法为整数除法。1.1核心思想分治法:将数组分成左右两部分,递归构建左子树和右子树。高度平衡:通过选择数组的中间元素作为根节点,确保左右子树的节点数尽可能相等,从而保证树的高度平衡。1.2具体步骤递归终止条件:如果左边
- LeetCode:199. 二叉树的右视图(C++带详细注释)
Axe涛
Leetcode题目二叉树队列数据结构leetcode算法
LeetCode:199.二叉树的右视图(C++带详细注释)/***Definitionforabinarytreenode.*structTreeNode{*intval;*TreeNode*left;*TreeNode*right;*TreeNode(intx):val(x),left(NULL),right(NULL){}*};*/classSolution{public:vectorrig
- 199.二叉树的右视图(C++逐句解析)
lcy_robotics
c++算法leetcode
classSolution{public:vectorrightSideView(TreeNode*root){//方法的类型是vector,需要的参数是节点类型queueque;//创建队列,队列里存的是节点类型if(root!=NULL)que.push(root);//如果根节点不是空的,把根节点放入队列vectorresult;//创建int类型容器,存放输出结果while(!=que.e
- 二叉树展开为链表C++
给你二叉树的根结点root,请你将它展开为一个单链表:展开后的单链表应该同样使用TreeNode,其中right子指针指向链表中下一个结点,而左子指针始终为null。展开后的单链表应该与二叉树先序遍历顺序相同。迭代法,创建了一个哨兵节点(先序遍历),用了栈,空间复杂度为O(n)classSolution{public:voidflatten(TreeNode*root){if(root==null
- 199. 二叉树的右视图 C++实现
给定一棵二叉树,想象自己站在它的右侧,按照从顶部到底部的顺序,返回从右侧所能看到的节点值。示例:输入: [1,2,3,null,5,null,4]输出: [1,3,4]解释:1rightSideView(TreeNode*root){//使用队列vectordata;queueque;if(root==NULL)returndata;que.push(root);intcurrent=1;//用于
- 力扣刷题第一天
C语言刷力扣题名C语言刷力扣一.无重复字符的最长子串二滑动窗口1.滑动窗口的核心思想有以下几点2.使用双指针进行窗口的维护left和right3.当出现重复时,需要找到一个出现重复的位置4.当出现重复时,修改对应left下标让我们直接看代码总结一.无重复字符的最长子串二滑动窗口1.滑动窗口的核心思想有以下几点2.使用双指针进行窗口的维护left和right3.当出现重复时,需要找到一个出现重复的位
- Golang发送定时邮件
white.tie
Golanggolang开发语言后端
前面尝试过用Python来发送邮件,下面测试一下Golang如何发送邮件需要使用三方库如下1.安装github.com/jordan-wright/emailgogetgithub.com/jordan-wright/email安装完成之后代码如下packagemainimport("github.com/jordan-wright/email""log""net/smtp")funcmain()
- 求解偏微分方程的Fourier展开式
解答:(1)求解的Fourier展开式考虑边值问题:∂2u∂t2=∂∂x((cosx+2)∂u∂x)−(sinπxl)u,(x,t)∈(0,l)×(0,T),\frac{\partial^2u}{\partialt^2}=\frac{\partial}{\partialx}\left((\cosx+2)\frac{\partialu}{\partialx}\right)-\left(\sin\
- MySQL server version for the right syntax to use near ''
KENYCHEN奉孝
1.配置不对,一直提示''com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:YouhaveanerrorinyourSQLsyntax;checkthemanualthatcorrespondstoyourMySQLserverversionfortherightsyntaxtousenear''atline1atsun.refle
- Vue 图片加载失败显示默认图片
数字浪儿
vuevue.js前端javascript
方法一:通过onerror属性加载默认图片exportdefault{data(){return{img:'',//访问图片的ip地址defaultImg:`this.src='${require('@/assets/images/right/default-person.png')}'`,};},}方法二:通过@error方法加载默认图片exportdefault{data(){return{i
- JavaScript爬虫使用API提取代理模板
q56731523
javascript爬虫开发语言
JavaScript爬虫有两大优势:直接执行页面JS(Puppeteer/Playwright)和解析SPA(单页应用)如React/Vue这就是我为何钟爱于JavaScript爬虫的原因。最近有几个同行说,使用API代理IP配合JavaScript经常报错,修改请求头或者访问频率也未能解决问题,因此,请求我们出手修改代码,一看代码简直惨不忍睹,能运行起来算他运气好,索性我自己写个通用模版给他参考
- 力扣打卡第十九天 左叶子之和
??tobenewyorker
leetcode算法c++数据结构
404.左叶子之和给定二叉树的根节点root,返回所有左叶子之和。示例1:输入:root=[3,9,20,null,null,15,7]输出:24解释:在这个二叉树中,有两个左叶子,分别是9和15,所以返回24示例2:输入:root=[1]输出:0提示:节点数在[1,1000]范围内-1000left&&!root->right)return0;intres=0;//后序遍历//左只有根据父节点才
- 双指针算法总结
程序员Andrew
常见算法算法C++leetcode
双指针常见的双指针有两种形式:对撞指针,左右指针。对撞指针:对撞指针一般用于顺序结构中,也称左右指针。•对撞指针从两端向中间移动。以个指针从最左端开始,另⼀个从最右端开始,然后逐渐往中间逼近。•对撞指针的终止条件⼀般是两个指针相遇或者错开(也可能在循环内部找到结果直接跳出循环),也就是:left==right(两个指针指向同一个位置)left>right(两个指针错开)快慢指针:快慢指针又称为龟兔
- 微信小程序入门四:实现table效果
鳄鱼儿
微信小程序小程序入门
微信小程序中没有table组件,那么怎么实现呢?其实使用多个view组件就可以实现,接下来就直接看代码吧标题1标题2标题3标题4标题5{{item}}{{item}}{{item}}{{item}}{{item}}/*.css*/page{font-size:14px;color:#333;}.table{border:1pxsolid#dadada;border-right:0;border-b
- ClickHouse 导入数据报错
愿与狸花过一生
ClickHouseclickhouse
报错信息ERROR:Thereisnolinefeed."�"foundinstead.It'slikeyourfilehasmorecolumnsthanexpected.Andifyourfilehastherightnumberofcolumns,maybeithasanunquotedstringvaluewithacomma.ClickHouse导入csv文件中发现多了一列导致报错解决方
- PgSQL内核特性 | Brin索引
yzs87
搜索引擎数据库
PgSQL内核特性|Brin索引数据库在进行过滤扫描或者join时,如果该表特别大,那么就需要顺序扫描表的所有数据然后进行过滤,或者扫描所有数据进行join条件探测。这对IO的负载影响特别大,当在join时,比如HashJoin的外表,需要对每个数据都进行Hash表探测,进一步影响性能。现有列存比如Infobright、Parquet、hydra等都对存储进行了类似的改进,在每个block中增加了
- Android 高通平台电池已调试好出货,客户要用新电池,驱动如何改用新增电池。
zzq1996
androidelasticsearch大数据
Android高通平台电池已调试好出货,客户又说要用新电池,驱动如何修改改用新增电池。开发云-一站式云服务平台Android高通平台按如下方法修改可以实现。+++b/kernel/arch/arm/boot/dts/batterydata-mtp-3900mah.dtsi@@-0,0+1,108@@+/*Copyright(c)2013,TheLinuxFoundation.Allrightsre
- LeetCode高频100题刷题记录之——二叉树的中序遍历
巍巍微澜
Leetcode刷题记录leetcode算法python二叉树
1问题描述给定一个二叉树,按照左,中,右的顺序遍历这棵树。2代码实现思路很简单,从左到右遍历这颗二叉树即可。2.1递归代码实现#Definitionforabinarytreenode.#classTreeNode:#def__init__(self,val=0,left=None,right=None):#self.val=val#self.left=left#self.right=right#
- 双指针题解——反转字符串【LeetCode】
潮_
我的学习记录双指针篇_刷题笔记开发语言数据结构算法leetcodepython
344.反转字符串一、算法逻辑(逐步通顺讲解每一步思路)该题要求将字符数组s原地反转,即不能使用额外数组,直接在输入数组上进行修改。✅1️⃣初始化双指针指针left指向起始位置(索引0);指针right指向末尾位置(索引len(s)-1);✅2️⃣使用双指针交换字符每次将s[left]与s[right]对换;然后将left向右移动一位,right向左移动一位;重复此过程,直到两个指针相遇或交叉(即
- Python二分查找库bisect
来个大包的二重积分
编程基础python算法排序算法
找暑期实习的时候做到某厂的笔试题里面用到这个,就总结一下。。。1.bisect_left(a,x,lo=0,hi=len(a))功能:在已排序序列a中查找元素x应该插入的位置,并返回最左侧的插入位置(index啊)。区别:如果有多个相同元素,bisect_left返回最左侧的插入位置。默认情况下,查找范围是整个序列a,但可以通过lo和hi参数来限制查找范围。2.bisect_right(a,x,l
- 151. 翻转字符串里的单词 ( 三种实现)
小可爱amour
每日一题C/C++leetcode字符串
题目要点:1:字符串首尾都有可能存在多余的空格2:字符串中间单词之间又可能存在连续多个空格解法1:从字符串手择单词,放到一个缓存数组里classSolution{private://传入字符串的左下标,确定单词的有效左右下标,右下标指向单词的下一位boolgetWord(conststring&s,intlen,int&left,int&right){while(left=len)returnfa
- 【Android当用户两次打断息屏操作后,屏幕将会在10分钟内无法熄灭并持续点亮(关闭Android13新增的dim功能)】
熊熊饲养员
Android开发笔记android
UndimDetectorWakeLock持锁导致屏幕不灭问题处理SOP问题描述在AndroidT版本中,系统新增了SCREEN_BRIGHT_WAKE_LOCK(UndimDetectorWakeLock)机制。当设备处于低亮度(dim)状态时,用户两次打断屏幕熄灭操作就会触发系统保持屏幕常亮10分钟,此行为符合系统设计预期。解决方案如需关闭该功能,请按以下步骤修改源码:1.修改源码文件路径:f
- playwright模块
qq_41119282
pythonplayrightUI自动化前端javascripthtml自动化
简写click()page.click("//input[@type='submit']")fill()page.locator("input[name=\"login_code\"]").fill("4121")page.fill("input[name=\'login_code\']","4121")等待元素.wait_for()page.locator("text=exampledomain
- [257] 二叉树的所有路径
紫菜(Nori)
数据结构与算法细节TODO算法数据结构leetcode
利用树的先序遍历,采用递归和迭代方式实现迭代方式有待优化/**@lcapp=leetcode.cnid=257lang=java**[257]二叉树的所有路径*///@lccode=start/***Definitionforabinarytreenode.*publicclassTreeNode{*intval;*TreeNodeleft;*TreeNoderight;*TreeNode(){}
- 使用 SQLite 和 Brighter 实现发件箱模式
actor_dev
c#.netbrightersqlite
简介本指南演示如何使用SQLite和.NET8,结合Brighter库实现**发件箱模式(OutboxPattern)**,以确保数据库更新与消息发布之间的事务一致性。项目目标处理CreateNewOrder命令,在事务成功时发布两个事件(OrderPlaced,OrderPaid)。如果发生错误(例如业务规则冲突),则回滚数据库更改和消息发布。要求.NET8+使用Podman(或Docker)运
- 面向对象面向过程
3213213333332132
java
面向对象:把要完成的一件事,通过对象间的协作实现。
面向过程:把要完成的一件事,通过循序依次调用各个模块实现。
我把大象装进冰箱这件事为例,用面向对象和面向过程实现,都是用java代码完成。
1、面向对象
package bigDemo.ObjectOriented;
/**
* 大象类
*
* @Description
* @author FuJian
- Java Hotspot: Remove the Permanent Generation
bookjovi
HotSpot
openjdk上关于hotspot将移除永久带的描述非常详细,http://openjdk.java.net/jeps/122
JEP 122: Remove the Permanent Generation
Author Jon Masamitsu
Organization Oracle
Created 2010/8/15
Updated 2011/
- 正则表达式向前查找向后查找,环绕或零宽断言
dcj3sjt126com
正则表达式
向前查找和向后查找
1. 向前查找:根据要匹配的字符序列后面存在一个特定的字符序列(肯定式向前查找)或不存在一个特定的序列(否定式向前查找)来决定是否匹配。.NET将向前查找称之为零宽度向前查找断言。
对于向前查找,出现在指定项之后的字符序列不会被正则表达式引擎返回。
2. 向后查找:一个要匹配的字符序列前面有或者没有指定的
- BaseDao
171815164
seda
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
public class BaseDao {
public Conn
- Ant标签详解--Java命令
g21121
Java命令
这一篇主要介绍与java相关标签的使用 终于开始重头戏了,Java部分是我们关注的重点也是项目中用处最多的部分。
1
- [简单]代码片段_电梯数字排列
53873039oycg
代码
今天看电梯数字排列是9 18 26这样呈倒N排列的,写了个类似的打印例子,如下:
import java.util.Arrays;
public class 电梯数字排列_S3_Test {
public static void main(S
- Hessian原理
云端月影
hessian原理
Hessian 原理分析
一. 远程通讯协议的基本原理
网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络 IO 来实现,其中传输协议比较出名的有 http 、 tcp 、 udp 等等, http 、 tcp 、 udp 都是在基于 Socket 概念上为某类应用场景而扩展出的传输协
- 区分Activity的四种加载模式----以及Intent的setFlags
aijuans
android
在多Activity开发中,有可能是自己应用之间的Activity跳转,或者夹带其他应用的可复用Activity。可能会希望跳转到原来某个Activity实例,而不是产生大量重复的Activity。
这需要为Activity配置特定的加载模式,而不是使用默认的加载模式。 加载模式分类及在哪里配置
Activity有四种加载模式:
standard
singleTop
- hibernate几个核心API及其查询分析
antonyup_2006
html.netHibernatexml配置管理
(一) org.hibernate.cfg.Configuration类
读取配置文件并创建唯一的SessionFactory对象.(一般,程序初始化hibernate时创建.)
Configuration co
- PL/SQL的流程控制
百合不是茶
oraclePL/SQL编程循环控制
PL/SQL也是一门高级语言,所以流程控制是必须要有的,oracle数据库的pl/sql比sqlserver数据库要难,很多pl/sql中有的sqlserver里面没有
流程控制;
分支语句 if 条件 then 结果 else 结果 end if ;
条件语句 case when 条件 then 结果;
循环语句 loop
- 强大的Mockito测试框架
bijian1013
mockito单元测试
一.自动生成Mock类 在需要Mock的属性上标记@Mock注解,然后@RunWith中配置Mockito的TestRunner或者在setUp()方法中显示调用MockitoAnnotations.initMocks(this);生成Mock类即可。二.自动注入Mock类到被测试类 &nbs
- 精通Oracle10编程SQL(11)开发子程序
bijian1013
oracle数据库plsql
/*
*开发子程序
*/
--子程序目是指被命名的PL/SQL块,这种块可以带有参数,可以在不同应用程序中多次调用
--PL/SQL有两种类型的子程序:过程和函数
--开发过程
--建立过程:不带任何参数
CREATE OR REPLACE PROCEDURE out_time
IS
BEGIN
DBMS_OUTPUT.put_line(systimestamp);
E
- 【EhCache一】EhCache版Hello World
bit1129
Hello world
本篇是EhCache系列的第一篇,总体介绍使用EhCache缓存进行CRUD的API的基本使用,更细节的内容包括EhCache源代码和设计、实现原理在接下来的文章中进行介绍
环境准备
1.新建Maven项目
2.添加EhCache的Maven依赖
<dependency>
<groupId>ne
- 学习EJB3基础知识笔记
白糖_
beanHibernatejbosswebserviceejb
最近项目进入系统测试阶段,全赖袁大虾领导有力,保持一周零bug记录,这也让自己腾出不少时间补充知识。花了两天时间把“传智播客EJB3.0”看完了,EJB基本的知识也有些了解,在这记录下EJB的部分知识,以供自己以后复习使用。
EJB是sun的服务器端组件模型,最大的用处是部署分布式应用程序。EJB (Enterprise JavaBean)是J2EE的一部分,定义了一个用于开发基
- angular.bootstrap
boyitech
AngularJSAngularJS APIangular中文api
angular.bootstrap
描述:
手动初始化angular。
这个函数会自动检测创建的module有没有被加载多次,如果有则会在浏览器的控制台打出警告日志,并且不会再次加载。这样可以避免在程序运行过程中许多奇怪的问题发生。
使用方法: angular .
- java-谷歌面试题-给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数
bylijinnan
java
public class SearchInShiftedArray {
/**
* 题目:给定一个固定长度的数组,将递增整数序列写入这个数组。当写到数组尾部时,返回数组开始重新写,并覆盖先前写过的数。
* 请在这个特殊数组中找出给定的整数。
* 解答:
* 其实就是“旋转数组”。旋转数组的最小元素见http://bylijinnan.iteye.com/bl
- 天使还是魔鬼?都是我们制造
ducklsl
生活教育情感
----------------------------剧透请原谅,有兴趣的朋友可以自己看看电影,互相讨论哦!!!
从厦门回来的动车上,无意中瞟到了书中推荐的几部关于儿童的电影。当然,这几部电影可能会另大家失望,并不是类似小鬼当家的电影,而是关于“坏小孩”的电影!
自己挑了两部先看了看,但是发现看完之后,心里久久不能平
- [机器智能与生物]研究生物智能的问题
comsci
生物
我想,人的神经网络和苍蝇的神经网络,并没有本质的区别...就是大规模拓扑系统和中小规模拓扑分析的区别....
但是,如果去研究活体人类的神经网络和脑系统,可能会受到一些法律和道德方面的限制,而且研究结果也不一定可靠,那么希望从事生物神经网络研究的朋友,不如把
- 获取Android Device的信息
dai_lm
android
String phoneInfo = "PRODUCT: " + android.os.Build.PRODUCT;
phoneInfo += ", CPU_ABI: " + android.os.Build.CPU_ABI;
phoneInfo += ", TAGS: " + android.os.Build.TAGS;
ph
- 最佳字符串匹配算法(Damerau-Levenshtein距离算法)的Java实现
datamachine
java算法字符串匹配
原文:http://www.javacodegeeks.com/2013/11/java-implementation-of-optimal-string-alignment.html------------------------------------------------------------------------------------------------------------
- 小学5年级英语单词背诵第一课
dcj3sjt126com
englishword
long 长的
show 给...看,出示
mouth 口,嘴
write 写
use 用,使用
take 拿,带来
hand 手
clever 聪明的
often 经常
wash 洗
slow 慢的
house 房子
water 水
clean 清洁的
supper 晚餐
out 在外
face 脸,
- macvim的使用实战
dcj3sjt126com
macvim
macvim用的是mac里面的vim, 只不过是一个GUI的APP, 相当于一个壳
1. 下载macvim
https://code.google.com/p/macvim/
2. 了解macvim
:h vim的使用帮助信息
:h macvim
- java二分法查找
蕃薯耀
java二分法查找二分法java二分法
java二分法查找
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月23日 11:40:03 星期二
http:/
- Spring Cache注解+Memcached
hanqunfeng
springmemcached
Spring3.1 Cache注解
依赖jar包:
<!-- simple-spring-memcached -->
<dependency>
<groupId>com.google.code.simple-spring-memcached</groupId>
<artifactId>simple-s
- apache commons io包快速入门
jackyrong
apache commons
原文参考
http://www.javacodegeeks.com/2014/10/apache-commons-io-tutorial.html
Apache Commons IO 包绝对是好东西,地址在http://commons.apache.org/proper/commons-io/,下面用例子分别介绍:
1) 工具类
2
- 如何学习编程
lampcy
java编程C++c
首先,我想说一下学习思想.学编程其实跟网络游戏有着类似的效果.开始的时候,你会对那些代码,函数等产生很大的兴趣,尤其是刚接触编程的人,刚学习第一种语言的人.可是,当你一步步深入的时候,你会发现你没有了以前那种斗志.就好象你在玩韩国泡菜网游似的,玩到一定程度,每天就是练级练级,完全是一个想冲到高级别的意志力在支持着你.而学编程就更难了,学了两个月后,总是觉得你好象全都学会了,却又什么都做不了,又没有
- 架构师之spring-----spring3.0新特性的bean加载控制@DependsOn和@Lazy
nannan408
Spring3
1.前言。
如题。
2.描述。
@DependsOn用于强制初始化其他Bean。可以修饰Bean类或方法,使用该Annotation时可以指定一个字符串数组作为参数,每个数组元素对应于一个强制初始化的Bean。
@DependsOn({"steelAxe","abc"})
@Comp
- Spring4+quartz2的配置和代码方式调度
Everyday都不同
代码配置spring4quartz2.x定时任务
前言:这些天简直被quartz虐哭。。因为quartz 2.x版本相比quartz1.x版本的API改动太多,所以,只好自己去查阅底层API……
quartz定时任务必须搞清楚几个概念:
JobDetail——处理类
Trigger——触发器,指定触发时间,必须要有JobDetail属性,即触发对象
Scheduler——调度器,组织处理类和触发器,配置方式一般只需指定触发
- Hibernate入门
tntxia
Hibernate
前言
使用面向对象的语言和关系型的数据库,开发起来很繁琐,费时。由于现在流行的数据库都不面向对象。Hibernate 是一个Java的ORM(Object/Relational Mapping)解决方案。
Hibernte不仅关心把Java对象对应到数据库的表中,而且提供了请求和检索的方法。简化了手工进行JDBC操作的流程。
如
- Math类
xiaoxing598
Math
一、Java中的数字(Math)类是final类,不可继承。
1、常数 PI:double圆周率 E:double自然对数
2、截取(注意方法的返回类型) double ceil(double d) 返回不小于d的最小整数 double floor(double d) 返回不大于d的整最大数 int round(float f) 返回四舍五入后的整数 long round