【c++笔记】有关计算时间的操作?!(新手速进)

2024-01-16 06:44

本文主要是介绍【c++笔记】有关计算时间的操作?!(新手速进),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

       今天主要是向大家介绍c++有关计算时间的两个函数以及输出技巧,运用函数的方法似乎更加简便高效,希望对您有所帮助。

目录

一、内容简介

二、正文部分

2-1 ceil与floor函数的介绍

1.ceil函数

 2、floor函数

 2-2 %-2d,%02d等的意义

三、例题 

四、结语 


一、内容简介

①ceil与floor的函数介绍+常用输出技巧

②有关时间计算的两个问题

二、正文部分

2-1 ceil与floor函数的介绍

1.ceil函数

|①向上取整数

ceil函数可以对小数进行向上取整操作,只需将要取整的小数作为ceil函数的入参即可,如:

#include <bits/stdc++.h>
using namespace std;
int main(){double num = 3.1;int n=ceil(num);printf("向上取整后得到的结果为:%d", n);
}

结果为

 |②向上取整小数位数

对于小数,ceil函数的用途更加广泛,它不仅可以将小数向上取整到整数位,还可以将小数的某一位向上取整,如下面的代码所示:

#include <bits/stdc++.h>
using namespace std;
void main(){double num = 3.1415926;printf("向上取整后得到的结果为:%f", ceil(num*100)/100.0);
}

结果为:

|③ 向上取整特殊边界值 

在进行向上取整操作时,有时会遇到特殊的边界值,在处理这些值时需要特殊考虑:

向上取整零值

当要取整的值为零时,结果仍为零,因为它已经是整数了

#include <bits/stdc++.h>
using namespace std;
void main(){double num = 0;printf("向上取整后得到的结果为:%f", ceil(num));
}

向上取整正负零值

当要取整的数值为正零或负零时,它们被视为相同的数值,结果仍为零。

#include <bits/stdc++.h>
using namespace std;
void main(){double num1 = 0;double num2 = -0.0;printf("num1和num2向上取整后的值分别为:%f, %f", ceil(num1), ceil(num2));
}

向上取整无限大值

当要取整的值为正无穷大时,结果也为正无穷大;当要取整的值为负无穷大时,结果为负无穷大。

#include <stdio.h>
#include <math.h>
void main(){double num1 = INFINITY;double num2 = -INFINITY;printf("num1和num2向上取整后的值分别为:%f, %f", ceil(num1), ceil(num2));
}

 2、floor函数

|① 取整

floor 函数主要用于对实数进行取整。对于一个实数 x,
floor()的计算方法是将x向下取整到最近的整数。例如:f1oor (2.3)= 2,£1oor(3.9)=3,f100r(-2.3)=-3e

|②辗转相除法

辗转相除法(又称欧几里德算法)是求两个数的最大公约数的一种方法,它使用到了 floor 函数。辗转相除法的基本思想是:将较大的数除以较小的数得到余数,然后再用较小的数去除以余数,直到余数为止。此时,较小的数即为原来两个数的最大公约数。 

|③求商和余数

在进行除法计算时,通常需要求商和余数。对于两个非零整数a 和b,我们可以通过如下方法求它们的商和余数:

 q= floor(a/ r)

r= a - bq

例如:
如果a=7,b=3,那么q= floor(7/3)=2,r=7-2*3=1。  

 2-2 %-2d,%02d等的意义

以下代码你都能准确说出他们所代表的意义吗?

#include <bits/stdc++.h>
using namespace std;
int main()
{int a=1;printf("%d\n",a);printf("%.2d\n",a);printf("%02d\n",a);printf("%-2d\n",a);return 0;	
} 

结果如下:

意义如下:

|①%.2d和%02d

2代表宽度,这两者的意义相同,指的是若不满足宽度则往前面补0

 |②%-2d

2代表宽度,此时表示不满足宽度时往后面补0

三、例题 

代码如下:

#include <bits/stdc++.h>
using namespace std;
int a1=24*60;//至少不超过一天,所以这里设置a1是提前一天的时间,a2是表示第二天8点 
int a2=8*60;
int main()
{int s,v;cin>>s>>v;int t=ceil((1.0*s)/v);//向上取最大整数 t+=10;//丢垃圾的10分钟 if(t<=a2){a2=a2-t;printf("%02d:%02d",a2/60,a2%60);}else{a1=a1+a2-t;printf("%02d:%02d",a1/60,a1%60);}return 0;
}

四、结语 

本次文章主要介绍了如何巧妙地用函数简单的解决时间问题,是值得c++入门选手参考的做题方式,希望对您有所帮助,如果有更好见解,欢迎来私信或者评论区进行讨论

希望能帮到您,蟹蟹~我们下次见~┏(^0^)┛


 

这篇关于【c++笔记】有关计算时间的操作?!(新手速进)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/611635

相关文章

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准