*******************求一时间加减函数*******************

lynx1111 2010-02-24 11:35:21
第一个输入参数:时间字符串,格式 2010-02-14 14:02:38 (如果此格式不方便,其他类似的格式也行)
第二个输入参数:数字,例子:8,-8
第三个输入参数:类型,共四种:D,H,M,S。表示天,小时,分,秒。
返回值为时间字符串

例子:
DatetimeAdd('2010-02-14 14:02:38',8,'D') 返回:2010-02-22 14:02:38
DatetimeAdd('2010-02-14 14:02:38',-8,'H') 返回:2010-02-14 06:02:38
DatetimeAdd('2010-02-14 14:02:38',-8,'M') 返回:2010-02-14 13:54:38
DatetimeAdd('2010-02-14 14:02:38',8,'S') 返回:2010-02-14 14:02:46

请写具体点,本人极端菜鸟。多谢!
...全文
312 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
最帅马老师 2010-02-24
  • 打赏
  • 举报
回复
引用 2 楼 hqin6 的回复:
C/C++ code#include<iostream>
#include<string>
#include<time.h>usingnamespace std;string DatetimeAdd(constchar* time,int num,char type)
{
time_t secs=0;switch (type)
{case'D':
secs= num*24*60*60;break;case'H':
secs= num*60*60;break;case'M':
secs= num*60;break;case'S':
secs= num;break;default:return"";
}struct tm _tmp;
strptime(time,"%Y-%m-%d %T",&_tmp);
time_t oldTime= mktime(&_tmp);
oldTime+= secs;struct tm* _res= localtime(&oldTime);char buf[20];
sprintf(buf,"%04d-%02d-%02d %02d:%02d:%02d", _res->tm_year+1900, _res->tm_mon+1, _res->tm_mday,
_res->tm_hour, _res->tm_min, _res->tm_sec);returnstring(buf);


}int main()
{char buf[20]="2010-02-14 14:02:38";
cout<< DatetimeAdd(buf,8,'D');return0;
}


正解
forster 2010-02-24
  • 打赏
  • 举报
回复
推荐COleDateTime类
是ctime的超集
ctime好像超过3000多年就异常了
COleDateTime支持到9999年
太乙 2010-02-24
  • 打赏
  • 举报
回复
#include <iostream>
#include <string>
#include <time.h>
using namespace std;

string DatetimeAdd(const char* time, int num, char type)
{
time_t secs = 0;
switch (type)
{
case 'D':
secs = num * 24 * 60 * 60;
break;
case 'H':
secs = num * 60 * 60;
break;
case 'M':
secs = num * 60;
break;
case 'S':
secs = num;
break;
default:
return "";
}
struct tm _tmp;
strptime(time, "%Y-%m-%d %T", &_tmp);
time_t oldTime = mktime(&_tmp);
oldTime += secs;
struct tm* _res = localtime(&oldTime);
char buf[20];
sprintf(buf,"%04d-%02d-%02d %02d:%02d:%02d", _res->tm_year + 1900, _res->tm_mon + 1, _res->tm_mday,
_res->tm_hour, _res->tm_min, _res->tm_sec);

return string(buf);


}
int main()
{
char buf[20] = "2010-02-14 14:02:38";
cout << DatetimeAdd(buf, 8, 'D');
return 0;
}
最帅马老师 2010-02-24
  • 打赏
  • 举报
回复
大概思路先用ctime类进行转换,然后加或减去相应值,再转为字符串即可

早上工作忙,下午帮你整一个
dskit 2010-02-24
  • 打赏
  • 举报
回复
/*test.cpp*/

#include<iostream>
#include<ctime>
#include<stdlib.h>

using namespace std;

int main(int argc, char* argv[])
{

char time[] = "2009-10-25 12:34:23";
struct tm t;
sscanf(time,"%d-%d-%d %d:%d:%d",&t.tm_year, &t.tm_mon, &t.tm_mday, &t.tm_hour, &t.tm_min, &t.tm_sec);
t.tm_year -= 1900;
t.tm_mon -= 1;
int diff = 0;
char type = 'D';
scanf("%d %c", &diff, &type);
time_t cur_t = 0;
cur_t = mktime(&t);
switch(type)
{
case 'D':
cur_t = cur_t + diff * 24 * 60 * 60;
break;
case 'H':
cur_t += diff * 60 * 60;
break;
case 'M':
cur_t += diff * 60;
break;
case 'S':
cur_t += diff;
break;
}

printf(asctime(&t));
printf(ctime(&cur_t));
return 0;
}


c++ test.cpp
./a.exe
2 D
.....

./a.exe
-2 D
.....
内容概要:本文提出一种基于融合鱼鹰搜索行为与柯西变异策略的改进麻雀优化算法(OCSSA),用于优化变分模态分解(VMD)的关键参数(如模态分量数K和惩罚因子α),以实现对滚动轴承振动信号的高效自适应分解,有效抑制模态混叠问题。经过OCSSA优化的VMD对原始信号进行预处理后,将分解得到的本征模态函数(IMF)重构为时频特征矩阵,作为卷积神经网络(CNN)的输入,以自动提取深层次的空间特征;随后,双向长短期记忆网络(BiLSTM)进一步挖掘特征序列中的前后向时序依赖关系,最终实现高精度的故障分类识别。该OCSSA-VMD-CNN-BiLSTM模型在西储大学公开轴承数据集上进行了充分验证,结果表明其在复杂噪声环境下对轴承不同故障类型与程度的诊断准确率显著优于传统方法,充分体现了智能优化算法与深度学习相结合在故障诊断领域的优越性能。; 适合人群:具备信号处理、机器学习及智能优化算法基础知识,从事机械装备状态监测、故障诊断、工业大数据分析等相关领域的科研人员、工程技术人员及高校研究生。; 使用场景及目标:①解决传统VMD参数依赖经验设定导致信号分解效果不稳定的问题;②提升强背景噪声和工况变化下滚动轴承早期微弱故障的检测灵敏度与分类准确率;③为智能制造和工业互联网背景下的关键设备智能运维与预测性维护提供一套可复现、高性能的技术解决方案。; 阅读建议:此资源以Matlab代码实现为核心,建议读者深入研读算法代码,重点理解OCSSA的寻优机制、VMD参数自适应选择过程以及CNN-BiLSTM的网络构建细节,通过复现完整实验流程,掌握从信号预处理、特征提取到智能分类的全流程关键技术,并尝试在自有数据集上进行迁移应用与性能对比。
源码链接: https://pan.quark.cn/s/a4b39357ea24 接口测试框架(基于json格式、http请,python3,不兼容python2.x版本) 注:现在基于Excel文件管理测试用例基本实现,) 备注:大家在运行的时候,如果参数不需要key,只需要字典,可以在ddt_case.py和case.py改造parame,注释掉现在的parem,启用新的即可 依赖用例支持用例执行,在testCase的ddt_case.py有实现,逻辑在代码中有写,参数的格式{"name":"$case1=data"}即代表name的值是case1的data字段,简单的实现。 依赖用例是简单的实现,具体在业务上面还有很多复杂的要处理,知识实现了,部分的思路。 (目前在部分window上会出现FileNotFoundError [Errno 2] No such file or directory,这个bug是路径过长,解决方案为吧log日志放在当前目录,或者修改动态生成的文件的名字,给了第一种方式,测试日志放在当前目录) qq交流群:194704520 Alt text 使用的库 requests,绝大部分是基于Python原有的库进行的,这样简单方便, 使用脚本参数分离等思想,尽可能降低代码的耦合度。 如果你不配置钉钉机器人,注释到机器人相关的代码 首先我们来看下我们的目录 Alt text ### 1.Case文件夹用来存放我们的测试用例相关的, test_case用来存储我们的测试数据,Excel管理测试用例,yaml文件管理测试用例,后续要把yaml管理测试用例的也封装出来。 Interface对测试接口相关的封装,包括requests库,发送...
内容概要:本文档围绕“配电网两阶段鲁棒故障恢复研究”展开,提供了完整的Matlab代码实现方案,属于高水平期刊论文的复现资料。研究针对配电网在发生故障后的恢复问题,提出了一种两阶段鲁棒优化方法,有效应对系统中诸如负荷波动、分布式电源出力不确定性等多重不确定因素。第一阶段进行预决策,包括网络重构、关键设备投切等操作;第二阶段则根据实际发生的故障场景进行动态调整与恢复控制,确保系统在故障后仍能安全、稳定、可靠运行。该资源不仅包含可运行的Matlab代码,还隶属于一个涵盖电力系统优化、智能算法、路径规划、机器学习等多个技术方向的综合性科研服务体系。; 适合人群:具备电力系统分析基础、优化理论知识及Matlab编程能力的研究生、科研人员和工程技术人员,特别适用于从事智能电网、配电自动化、故障恢复策略、鲁棒优化等领域研究的专业人士。; 使用场景及目标:① 学习并复现顶刊关于配电网故障恢复的先进优化模型;② 掌握两阶段鲁棒优化在电力系统中的建模思路、解流程与技术细节;③ 利用所提供的Matlab代码进行算法验证、仿真测试,并在此基础上开展扩展性科研工作,如改进模型、引入新约束或应用于其他系统。; 阅读建议:建议结合经典电力系统优化与鲁棒调度相关文献,深入理解两阶段鲁棒优化的数学建模原理与物理背景,通过实际运行和调试代码,观察不同参数设置对优化结果的影响,进而掌握算法的核心机制。同时可参考文档中提及的其他相关研究主题,拓展研究视野,推动科研创新。

65,210

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧