社区讨论

0分求助,全WA

P5661[CSP-J 2019] 公交换乘参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lo17i99e
此快照首次捕获于
2023/10/22 16:28
2 年前
此快照最后确认于
2023/11/02 16:07
2 年前
查看原帖
欢迎指导
代码如下
CPP
#include<bits/stdc++.h>
using namespace std;
struct node{
	int bors;
	int time;
	int money;
	bool cheap;
};
node data[1001];
int n,ticket=0;
void find(int n,int m){
	for(int k=1;k<=n;k++){
		if(data[k].cheap==false||data[k].money<data[m].money||data[k].time-data[m].time>45)
		ticket+=data[m].money;
		else ticket+=0;
	}
	return;
}
int main(){
cin>>n;
for(int i=1;i<=n;i++){
cin>>data[i].bors>>data[i].money>>data[i].time;
if(i==1)
ticket+=data[i].money;
if(data[i].bors==0)
data[i].cheap=true;
else data[i].cheap=false;
}
for(int i=1;i<=n;i++){
	if(data[i].bors==0)
	ticket=ticket+data[i].money;
	else find(n,i);
}
cout<<ticket<<endl;
return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...