观光公交

Description
风景迷人的小城 Y 市,拥有 n 个美丽的景点。由于慕名而来的游客越来越多,Y 市特意安排了一辆观光公交车,为游客提供更便捷的交通服务。观光公交车在第 0 分钟出现在 1号景点,随后依次前往 2、3、4……n 号景点。从第 i 号景点开到第 i+1 号景点需要 Di 分钟。任意时刻,公交车只能往前开,或在景点处等待。

设共有 m 个游客,每位游客需要乘车 1 次从一个景点到达另一个景点,第 i 位游客在Ti 分钟来到景点 Ai,希望乘车前往景点 Bi(Ai<Bi)。为了使所有乘客都能顺利到达目的地,公交车在每站都必须等待需要从该景点出发的所有乘客都上车后才能出发开往下一景点。假设乘客上下车不需要时间。

一个乘客的旅行时间,等于他到达目的地的时刻减去他来到出发地的时刻。因为只有一辆观光车,有时候还要停下来等其他乘客,乘客们纷纷抱怨旅行时间太长了。于是聪明的司机 ZZ 给公交车安装了 k 个氮气加速器,每使用一个加速器,可以使其中一个 Di 减 1。对于同一个 Di 可以重复使用加速器,但是必须保证使用后 Di 大于等于 0。

那么 ZZ 该如何安排使用加速器,才能使所有乘客的旅行时间总和最小?

Input
第 1 行是 3 个整数 n, m, k,每两个整数之间用一个空格隔开。分别表示景点数、乘客数和氮气加速器个数。

第 2 行是 n-1 个整数,每两个整数之间用一个空格隔开,第 i 个数表示从第 i 个景点开往第 i+1 个景点所需要的时间,即 Di。

第 3 行至 m+2 行每行 3 个整数 Ti, Ai, Bi,每两个整数之间用一个空格隔开。第 i+2 行表示第 i 位乘客来到出发景点的时刻,出发的景点编号和到达的景点编号。

Output
共一行,包含一个整数,表示最小的总旅行时间。

Sample Input
3 3 2
1 4
0 1 3
1 1 2
5 2 3

Sample Output
10

Data Constraint

Hint
【输入输出样例说明】

对 D2 使用 2 个加速器,从 2 号景点到 3 号景点时间变为 2 分钟。

公交车在第 1 分钟从 1 号景点出发, 第2 分钟到达 2 号景点, 第5 分钟从 2 号景点出发,第 7 分钟到达 3 号景点。

第 1 个旅客旅行时间 7-0 = 7 分钟。

第 2 个旅客旅行时间 2-1 = 1 分钟。

第 3 个旅客旅行时间 7-5 = 2 分钟。

总时间 7+1+2 = 10 分钟。

【数据范围】

对于 10%的数据,k=0;

对于 20%的数据,k=1;

对于 40%的数据,2 ≤ n ≤ 50,1 ≤ m ≤ 1,000,0 ≤ k ≤ 20,0 ≤ Di ≤ 10,0 ≤ Ti ≤ 500;

对于 60%的数据,1 ≤ n ≤ 100,1 ≤ m ≤ 1,000,0 ≤ k ≤ 100,0 ≤ Di ≤ 100,0 ≤ Ti ≤ 10,000;

对于 100%的数据,1 ≤ n ≤ 1,000,1 ≤ m ≤ 10,000,0 ≤ k ≤ 100,000,0 ≤ Di ≤ 100,

0 ≤ Ti ≤ 100,000。

.
.
.
.
.
分析
贪心

我们首先记录下来到每一站下车的人数,然后枚举每一个加速器,由于每个乘客的旅行时间只与他到达的时间与下车的时间有关,因此,我们在枚举每一个加速器的时候,只需要把能够造福最多人的那一段路加速即可,于是我们可以记录每一段路所造福的人数,我们暂定每个景点的出发时间为需要从该景点上车的最晚到达的乘客,那么到达时间即为上一个景点的出发时间或到达时间更大的一个值加上从上一个景点到该景点所需要的时间。如果某个景点的出发时间小于到达时间,那么说明若在这段旅程中使用加速器,能够造福到下一个景点下车的人。通过这个,我们就可以贪心了,然后每次贪心完之后都更新到达景点的时间即可。为了方便计算,我在初始化的时候把所有人的到达景点的时间都减去,这样就不用最后再减了,就可以直接求需要在每个景点下车的人数*到达该景点的时间的和就行了。

.
.
.
.
.
.
程序:

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int d[1010],num[1010],last[1010],time1[1010],data[1010];

int main()
{
	int n,m,k,ans=0;
	scanf("%d%d%d",&n,&m,&k);
	for (int i=2;i<=n;i++)
		scanf("%d",&d[i]);
	for (int i=1;i<=m;i++)
	{
		int a,b,c;
		scanf("%d%d%d",&a,&b,&c);
		ans-=a;
		num[c]++;
		last[b]=max(last[b],a);
	}
	for (int i=2;i<=n;i++)
		time1[i]=max(time1[i-1],last[i-1])+d[i];
	int bz=0;
	for (int i=1;i<=k;i++)
	{
		for (int j=n;j>=2;j--)
		{
			data[j]=num[j];
			if (last[j]<time1[j]) data[j]+=data[j+1];
		}
		int max1=0;
		for (int j=2;j<=n;j++)
			if (data[j]>max1&&d[j]>0)
			{
				max1=data[j];
				bz=j;
			}
		d[bz]--;
		for (int j=bz;j<=n;j++)
			time1[j]=max(time1[j-1],last[j-1])+d[j];
	}
	for (int i=2;i<=n;i++)
		ans+=num[i]*time1[i];
	printf("%d",ans);
	return 0;
}
#include"string.h" #include"usersys.h" #include"userpar.h" #include"useruart.h" #include"usersram.h" #include"useruart_exter.h" #include"usart.h" #include "update_fpga_gw2a.h" #define ACK_RS422 1 #define ACK_NET 2 #define host_cmd_0 0x00 #define host_cmd_1 0x01 #define host_cmd_2 0x02 #define host_cmd_3 0x03 #define host_cmd_4 0x04 #define host_cmd_5 0x05 #define host_cmd_F 0x0F #define sub_cmd_0 0x00 #define sub_cmd_1 0x01 #define sub_cmd_2 0x02 #define sub_cmd_3 0x03 #define sub_cmd_4 0x04 #define sub_cmd_5 0x05 #define sub_cmd_6 0x06 #define sub_cmd_7 0x07 #define sub_cmd_8 0x08 #define sub_cmd_9 0x09 #define sub_cmd_a 0x0a #define sub_cmd_b 0x0b #define sub_cmd_c 0x0c #define sub_cmd_d 0x0d #define sub_cmd_e 0x0e #define sub_cmd_f 0x0f #define sub_cmd_10 0x10 #define sub_cmd_11 0x11 #define sub_cmd_12 0x12 #define sub_cmd_13 0x13 #define sub_cmd_14 0x14 #define sub_cmd_f1 0xf1 #define sub_cmd_f2 0xf2 #define cmd_update_read_par_ack 0x64//¶Á²ÎÊýÓ¦´ðÖ¸Áî #define cmd_update_write_par 0x63//д²ÎÊýÖ¸Áî #define cmd_update_read_par 0x61//¶Á²ÎÊýÖ¸Áî #define cmd_update_write_par_ack 0x60//д²ÎÊýÓ¦´ðÖ¸Áî uartPro_Typedef uartPro_422,uartPro_net; uartPro_Typedef uartPro_com; #define EXTER_UARTRXFRAMELEN 9 #define UART_EXTER_FRAME_HEAD 0XA0 #define EXTER_UARTRXFRAMELEN_UPDATE 1100 void useruart_exter_Init(void) { uartPro_422.buf_full = FALSE; uartPro_net.buf_full = FALSE; HAL_GPIO_WritePin(GPIOA, GPIO_PIN_11, GPIO_PIN_SET); } void useruart_exter_NetRx(uint8_t tmp) { uint8_t i = 0; if(userpar_Get_workmode() == uddate_work_mode) { uartPro_net.rxDsp_Buf[uartPro_net.rx_len++]=tmp; UserTimer_SetPeroid(TIMER_NET_IDLE_PERIOD,TIMER_NET_IDLE_OPT); if(uartPro_net.rx_len >= EXTER_UARTRXFRAMELEN_UPDATE) { uartPro_net.rx_len = 0; } } else { for(i = 0;i < (EXTER_UARTRXFRAMELEN-1);i++) { uartPro_net.rxDsp_Buf[i] = uartPro_net.rxDsp_Buf[i+1]; } uartPro_net.rxDsp_Buf[EXTER_UARTRXFRAMELEN-1]=tmp; if((uartPro_net.rxDsp_Buf[EXTER_UARTRXFRAMELEN-1] == UARTFRAMEEND) && (uartPro_net.rxDsp_Buf[0] == UARTFRAMEHEAD)) { uartPro_net.buf_full = TRUE; } } } void useruart_Rs422Rx(uint8_t tmp) { uint8_t i = 0; if(userpar_Get_workmode() == uddate_work_mode) { uartPro_422.rxDsp_Buf[uartPro_422.rx_len++]=tmp; UserTimer_SetPeroid(TIMER_RS422_IDLE_PERIOD,TIMER_RS422_IDLE_OPT); if(uartPro_422.rx_len >= EXTER_UARTRXFRAMELEN_UPDATE) { uartPro_422.rx_len = 0; } } else { for(i = 0;i < (EXTER_UARTRXFRAMELEN-1);i++) { uartPro_422.rxDsp_Buf[i] = uartPro_422.rxDsp_Buf[i+1]; } uartPro_422.rxDsp_Buf[EXTER_UARTRXFRAMELEN-1]=tmp; if((uartPro_422.rxDsp_Buf[EXTER_UARTRXFRAMELEN-1] == UARTFRAMEEND) && (uartPro_422.rxDsp_Buf[0] == UARTFRAMEHEAD)) { uartPro_422.buf_full = TRUE; } } } unsigned short CRC16_MODBUS(unsigned char *ptr, int len) { unsigned int i; unsigned short crc = 0xFFFF; while(len--) { crc ^= *ptr++; for (i = 0; i < 8; ++i) { if (crc & 1) crc = (crc >> 1) ^ 0xA001; else crc = (crc >> 1); } } return crc; } #define MCU__UPDATE_DST_ID 0x0001 #define FPGA_UPDATE_DST_ID 0x0002 #define PACK_BYTES_LEN 1000 uint32_t now_pack_cnt; uint32_t pack_bytes = 0; void useruart_exter_Handle_Update_Commun(void) { uint8_t now_ack = ACK_RS422; // uint8_t checksum = 0,i; // uint8_t now_ack = ACK_RS422; uint8_t *pBuf = uartPro_com.rxDsp_Buf; // uint32_t RegValue; uint16_t nowCalCRC,nowRxCRC; uint16_t src_id,dst_id; uint16_t now___pack_num,total_pack_num; uint32_t len; if(UserTimer_InqIsTrigger(TIMER_NET_IDLE_OPT) == TRUE) { memcpy(uartPro_com.rxDsp_Buf,uartPro_net.rxDsp_Buf,uartPro_net.rx_len); uartPro_com.buf_full = TRUE; uartPro_com.rx_len = uartPro_net.rx_len; uartPro_net.rx_len = 0; now_ack = ACK_NET; } else if(UserTimer_InqIsTrigger(TIMER_RS422_IDLE_OPT) == TRUE) { memcpy(uartPro_com.rxDsp_Buf,uartPro_422.rxDsp_Buf,uartPro_422.rx_len); uartPro_com.buf_full = TRUE; uartPro_com.rx_len = uartPro_422.rx_len; uartPro_422.rx_len = 0; now_ack = ACK_RS422; } else { uartPro_com.buf_full = FALSE; } if(uartPro_com.buf_full == TRUE) { if(uartPro_com.rx_len > 2) { nowCalCRC = CRC16_MODBUS(pBuf,uartPro_com.rx_len-2); } nowRxCRC = (unsigned short)(pBuf[uartPro_com.rx_len-2] << 8) + (unsigned short)(pBuf[uartPro_com.rx_len-1] << 0); len = (pBuf[2] << 8) + (pBuf[3] << 0); src_id = (pBuf[4] << 8) + (pBuf[5] << 0); dst_id = (pBuf[6] << 8) + (pBuf[7] << 0); now___pack_num = (pBuf[10] << 8) + (pBuf[11] << 0); total_pack_num = (pBuf[12] << 8) + (pBuf[13] << 0); if((pBuf[0] == UART_EXTER_FRAME_HEAD) && (nowCalCRC == nowRxCRC) && (len == (uartPro_com.rx_len-4))) { uartPro_com.tx_len = 0; uartPro_com.tx_buf[uartPro_com.tx_len++] = UART_EXTER_FRAME_HEAD; switch(pBuf[1]) { // case cmd_update_read_par: // // break; case cmd_update_write_par: uartPro_com.tx_buf[uartPro_com.tx_len++] = cmd_update_write_par_ack; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0; switch(pBuf[8]) { case host_cmd_0: switch(pBuf[9]) { case sub_cmd_1://ÎÕÊÖ uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[8]; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[9]; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x00; if(dst_id == MCU__UPDATE_DST_ID) { userpar_Erase_mcu_update_pack(); } else if(dst_id == FPGA_UPDATE_DST_ID) { //SRAM¿ÉÒÔ²»²Á³ý } now_pack_cnt = 0; pack_bytes = 0; break; case sub_cmd_2://Éý&frac14;¶°ü now_pack_cnt++; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[8]; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[9]; if(now_pack_cnt != now___pack_num) { uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x02; } else { if(now___pack_num > total_pack_num) { uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x01; } else { uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x00; if(dst_id == MCU__UPDATE_DST_ID) { userpar_write_mcu_update_pack(uartPro_com.rx_len-16,(uint8_t*)&pBuf[14],(now___pack_num-1) * PACK_BYTES_LEN); } else if(dst_id == FPGA_UPDATE_DST_ID) { usersram_write_data(&pBuf[14], uartPro_com.rx_len-16,base_addr_sram + PACK_BYTES_LEN*(now___pack_num-1)); } pack_bytes = pack_bytes + uartPro_com.rx_len-16; } } break; case sub_cmd_3://ÕûÌåУÑé sha256 uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[8]; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[9]; if(dst_id == MCU__UPDATE_DST_ID) { userpar_write_mcu_update_bytes(pack_bytes,MCU_UPDATE_PACK_LEN_OFFSET_ADDR);//Ò»¶¨Ê¹Óà userpar_write_mcu_update_flag_write(MCU_UPDATE_FLAG_OFFSET_ADDR,MCU_UPDATE_FLAG); uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x00; //userpar_update_trig_warn_state(1); } else if(dst_id == FPGA_UPDATE_DST_ID) { //userpar_trig_fpga_jtag_update(); usersram_write_size(pack_bytes);//Ò»¶¨Ê¹Óà if(user_update_fpga_gw2a() == TRUE) { uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x00; } else { uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x01; } // userpar_update_trig_warn_state(1); } break; } break; } break; default: uartPro_com.tx_buf[uartPro_com.tx_len++] = cmd_update_write_par_ack; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[8]; uartPro_com.tx_buf[uartPro_com.tx_len++] = pBuf[9]; uartPro_com.tx_buf[uartPro_com.tx_len++] = 0x05; break; } uartPro_com.tx_buf[2] = 0;// - 2; uartPro_com.tx_buf[3] = uartPro_com.tx_len-2; nowCalCRC = CRC16_MODBUS(uartPro_com.tx_buf,uartPro_com.tx_len); uartPro_com.tx_buf[uartPro_com.tx_len++] = (nowCalCRC >> 8) & 0xff; uartPro_com.tx_buf[uartPro_com.tx_len++] = (nowCalCRC >> 0) & 0xff; if(now_ack == ACK_RS422) { HAL_UART_Transmit(&USART_RS422_USER,uartPro_com.tx_buf,uartPro_com.tx_len,1000); } else { HAL_UART_Transmit(&USART_NET_USER,uartPro_com.tx_buf,uartPro_com.tx_len,1000); } } uartPro_com.rx_len = 0; uartPro_com.buf_full = FALSE; } } void useruart_exter_Handle_Normal_Commun(void) { uint8_t checksum = 0,i; uint8_t now_ack = ACK_RS422; uint8_t *pBuf = NULL; uint32_t tmp; uint8_t *pcal; if((uartPro_422.buf_full == TRUE) || (uartPro_net.buf_full == TRUE)) { if(uartPro_422.buf_full == TRUE) { pBuf = uartPro_422.rxDsp_Buf; now_ack = ACK_RS422; } else if(uartPro_net.buf_full == TRUE) { pBuf = uartPro_net.rxDsp_Buf; now_ack = ACK_NET; } uartPro_422.buf_full = FALSE; uartPro_net.buf_full = FALSE; for(i = 1;i < (EXTER_UARTRXFRAMELEN-2);i++) { checksum = checksum + pBuf[i]; } if(checksum != pBuf[EXTER_UARTRXFRAMELEN-2]) { return; } uartPro_422.tx_len = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = UARTFRAMEHEAD; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[1]; switch(pBuf[1]) { case cmd01: userpar_SetPACtl_Soft(pBuf[6]); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd06: userpar_SetPAAtt_Soft(pBuf[6]); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd0F: uartPro_net.rx_len = 0; uartPro_422.rx_len = 0; userpar_Set_workmode(pBuf[6]); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd81: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetPACtl_Soft(); break; case cmd86: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetPAAtt_Soft(); break; case cmd82: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; tmp = userpar_GetRD_Power(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); tmp = userpar_GetFD_Power(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); break; case cmd83: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; tmp = userpar_GetPA_Vol(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); tmp = userpar_GetPA_Curr(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); break; case cmd84: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetPA_State(); uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetTemp(); break; case cmd85: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetFun1_Curr(); uartPro_422.tx_buf[uartPro_422.tx_len++] = userpar_GetFun2_Curr(); break; case cmd0A: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; tmp = (pBuf[3] << 24) | (pBuf[4] << 16) | (pBuf[5] << 8) | pBuf[6] ; userpar_SetFreq(tmp); tmp = userpar_GetFreq(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 24) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 16) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); break; case cmd8A: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; tmp = userpar_GetFreq(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 24) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 16) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); break; case cmd71://ͨµÀ1ÊäÈ빦ÂÊ pcal = userpar_correct_detectvol_inputpower_ch1(pBuf[2]); memcpy(pcal,(uint8_t*)&pBuf[3],4); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd72://ͨµÀ1Êä³ö¹¦ÂÊ pcal = userpar_correct_detectvol_outputpower_ch1(pBuf[2]); memcpy(pcal,(uint8_t*)&pBuf[3],4); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd73://ͨµÀ1ÊäÈ빦ÂÊ userpar_SavePower_vol(); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd74://ͨµÀ1ÕýÏò¹¦ÂÊÃÅÏÞ pcal = userpar_correct_ch1_jb_fd_power(); memcpy(pcal,(uint8_t*)&pBuf[3],4); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd75://ͨµÀ1פ²¨²îÖµ pcal = userpar_correct_ch1_jb_dlt(); memcpy(pcal,(uint8_t*)&pBuf[3],4); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmd76://ͨµÀ1פ²¨²îÖµ userpar_Save_swrPar(); uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[2]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[3]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[4]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[5]; uartPro_422.tx_buf[uartPro_422.tx_len++] = pBuf[6]; break; case cmdF1://ͨµÀ1ÊäÈ빦ÂÊ uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; pcal = userpar_correct_detectvol_inputpower_ch1(pBuf[2]); memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); uartPro_422.tx_len = uartPro_422.tx_len + 4; break; case cmdF2://ͨµÀ1Êä³ö¹¦ÂÊ uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; pcal = userpar_correct_detectvol_outputpower_ch1(pBuf[2]); memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); uartPro_422.tx_len = uartPro_422.tx_len + 4; break; case cmdF4://ͨµÀ1ÕýÏò¹¦ÂÊÃÅÏÞ uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; pcal = userpar_correct_ch1_jb_fd_power(); memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); uartPro_422.tx_len = uartPro_422.tx_len + 4; break; case cmdF5://ͨµÀ1פ²¨²îÖµ uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; pcal = userpar_correct_ch1_jb_dlt(); memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); uartPro_422.tx_len = uartPro_422.tx_len + 4; break; // case cmdFA://ͨµÀ1ÊäÈë&frac14;첨µçѹ // uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; // pcal = userpar_advol_input_ch1(); // memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); // uartPro_422.tx_len = uartPro_422.tx_len + 4; // break; case cmdFB://ͨµÀ1Êä³ö&frac14;첨µçѹ uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; pcal = userpar_advol_output_ch1(); memcpy((uint8_t*)&uartPro_422.tx_buf[uartPro_422.tx_len],pcal,4); uartPro_422.tx_len = uartPro_422.tx_len + 4; break; case cmd8F: uartPro_422.tx_buf[uartPro_422.tx_len++] = 0; tmp = userpar_get_pa_run_timer_1s(); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 24) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 16) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 8) & 0xff); uartPro_422.tx_buf[uartPro_422.tx_len++] = ((tmp >> 0) & 0xff); break; default: break; } checksum = 0; for(i = 1;i < uartPro_422.tx_len;i++) { checksum = checksum + uartPro_422.tx_buf[i]; } uartPro_422.tx_buf[uartPro_422.tx_len++] = checksum; uartPro_422.tx_buf[uartPro_422.tx_len++] = UARTFRAMEEND; if(now_ack == ACK_RS422) { HAL_UART_Transmit(&USART_RS422_USER,uartPro_422.tx_buf,uartPro_422.tx_len,1000); } else { HAL_UART_Transmit(&USART_NET_USER,uartPro_422.tx_buf,uartPro_422.tx_len,1000); } } } void useruart_exter_Handle(void) { if(userpar_Get_workmode() == normal_work_mode) { useruart_exter_Handle_Normal_Commun(); } else { useruart_exter_Handle_Update_Commun(); } }
最新发布
11-14
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值