9-1 时间换算

// 时间换算 
#include <stdio.h>

struct Time {
	int hour;
	int minute;
	int second;
};

void CalTime(struct Time *p, int n);

int main(void)
{
	int n;				// n秒后 
	struct Time t;
	
	printf("请输入时: ");
	scanf("%d",&t.hour);
	printf("请输入分: ");
	scanf("%d",&t.minute);
	printf("请输入秒: ");
	scanf("%d",&t.second);
	printf("当前时间: %d:%d:%d\n",t.hour,t.minute,t.second);
	
	printf("请输入秒数: ");
	scanf("%d",&n);
	
	CalTime(&t,n);
	
	printf("过%d秒后时间为: ",n);
	printf("%d:%d:%d\n",t.hour,t.minute,t.second);
	
	return 0;
}

void CalTime(struct Time *p, int n)
{
	int ds, dm, dh;		// 秒分时的增量 
	
	dh = n/3600;
	dm = (n-dh*3600)/60;
	ds = n-dh*3600-dm*60;
	
	p->hour += dh;
	p->minute += dm;
	p->second += ds;
	
	if (p->second>=60)
	{
		p->second %= 60;
		p->minute += 1;
	}
	if (p->minute>=60)
	{
		p->minute %= 60;
		p->hour += 1;
	}	
	// 超过24点就从0点开始计时 
	if (p->hour>=24)
	{
		p->hour %= 24;
	}	
}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
算法设计: 1. 将原始数据按照车牌号码进行分组,得到每辆车的所有记录。 2. 对于每辆车的所有记录,按照时间升序排序。 3. 对于每辆车的每条记录,判断其所在的车道编号,判断其是否驶入或驶出了上下游路段,记录其进入或离开的时间(时间换算列中的值)。 4. 将所有车辆的进入离开信息记录到两张表中,用车牌号作为关键字。 具体步骤如下: 1. 导入pandas库,并读取原始数据。 import pandas as pd df = pd.read_csv('xxx.csv', delimiter=',') # 假设数据已经按时间升序排好。 2. 对原始数据按车牌号进行分组,得到每辆车的所有记录。 grouped = df.groupby('车牌号') 3. 对于每辆车的所有记录,按照时间升序排序,然后判断其所在的车道编号,判断其是否驶入或驶出了上下游路段,记录其进入或离开的时间。 # 创建两个空表,分别代表上下游路段的车辆数据 table_up = pd.DataFrame(columns=['车牌号', '进入时间', '离开时间']) table_down = pd.DataFrame(columns=['车牌号', '进入时间', '离开时间']) # 循环处理每辆车 for name, group in grouped: # 按照时间升序排序 group = group.sort_values(by=['时间换算']) # 判断进入或离开上下游路段,并记录时间 enter_up_time = None enter_down_time = None leave_up_time = None leave_down_time = None for i, row in group.iterrows(): if row['检测器ID'] == '6269' or row['检测器ID'] == '6271': # 进入上游路段 if not enter_up_time: enter_up_time = row['时间换算'] # 离开上游路段 else: leave_up_time = row['时间换算'] elif row['检测器ID'] == '6271' or row['检测器ID'] == '6273': # 进入下游路段 if not enter_down_time: enter_down_time = row['时间换算'] # 离开下游路段 else: leave_down_time = row['时间换算'] # 记录进入离开信息到对应的表中 if enter_up_time and leave_up_time: table_up = table_up.append({'车牌号': name, '进入时间': enter_up_time, '离开时间': leave_up_time}, ignore_index=True) if enter_down_time and leave_down_time: table_down = table_down.append({'车牌号': name, '进入时间': enter_down_time, '离开时间': leave_down_time}, ignore_index=True) 4. 将所有车辆的进入离开信息记录到两张表中,用车牌号作为关键字。 # 保存两个表格到csv文件中 table_up.to_csv('table_up.csv', index=False) table_down.to_csv('table_down.csv', index=False) 这样就得到了两张表,分别记录了上下游路段的车辆进出信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值