#include<iostream>
using namespace std;
struct workspace {
int ID;
int price;
int incoming_amount;
int outgoing_amount;
int date;
};
int main ()
{
workspace works[5];
string type_amount;
int incoming_IDs[5];
int incoming_IDs_counter = 0;
for(int i = 0; i < 5; i++){
cin >> works[i].ID;
cin >> works[i].price;
cout << "What type of amount (inc/out)?" << endl;
cin >> type_amount;
if(type_amount == "inc"){
incoming_IDs[incoming_IDs_counter] = works[i].ID;
incoming_IDs_counter++;
works[i].outgoing_amount = 0;
cin >> works[i].incoming_amount;
}
else if(type_amount == "out"){
works[i].incoming_amount = 0;
cin >> works[i].outgoing_amount;
}
cin >> works[i].date;
}
return 0;
}
这是我的代码到目前为止,现在我必须检查以下内容:
确保ID添加了一个传入金额,然后才能作为传出金额。
确保传入金额的价格小于传出金额。
所以,我在第一个工作,我得到了这个功能:
bool INC_Exists(workspace &works, int &incoming_IDs_counter, int incoming_IDs[]){
for(int i = 0; i < incoming_IDs_counter; i++){
if(incoming_IDs[i] == works.ID){
return true;
break;
}
}
return false;
}
它似乎起作用并完成了工作,但对于第二个,我不知道如何解决它。如何有效地检查传出金额的价格是否小于相同ID的传入金额?
答案 0 :(得分:3)
bool Valid_Price(workspace *works, int& incoming_IDs_counter, int incoming_IDs[], workspace &workz){
bool valid_price;
for(int j = 0; j < incoming_IDs_counter; j++){
if(incoming_IDs[j] == workz.ID){
for(int k = 0; k < 5; k++){
if(works[k].ID == workz.ID){
if(works[k].price < workz.price){
valid_price = true;
}
else if(works[k].price > workz.price){
valid_price = false;
}
}
}
}
}
return valid_price;
}
经过测试,似乎有效......
答案 1 :(得分:1)
此功能
bool INC_Exists(workspace &works, int &incoming_IDs_counter, int incoming_IDs[]){
for(int i = 0; i < incoming_IDs_counter; i++){
if(incoming_IDs[i] == works.sifra){
return true;
break;
}
}
return false;
}
无效,因为结构工作区没有数据成员sifra,
如果我已正确理解要求
•确保ID之前已添加传入金额 出局金额
你需要检查对象是否在int incoming_IDs []的元素中。该功能可以采用以下方式
bool INC_Exists( const int incoming_IDs[], int incoming_IDs_counter, const workspace &works )
{
int i = 0;
while ( i < incoming_IDs_counter && works.ID != incoming_IDs[ i ] ) i++;
return ( i != incoming_IDs_counter );
}
至于这个条件
•确保传入金额的价格小于传出金额 量
然后它可以用表达式
表示works.price < works. outgoing_amount
但我不知道这个条件必须在哪里使用。根据你的描述,目前还不清楚。
答案 2 :(得分:1)
bool Valid_Price(workspace *works, int& incoming_IDs_counter, int incoming_IDs[], workspace &workz){
for(int i = 0; i < 5; i++){
for(int j = 0; j < incoming_IDs_counter; j++){
if(incoming_IDs[j] == workz.ID){
for(int k = 0; k < 5; k++){
if(works[k].price < workz.price){
return true;
}
else{
return false;
}
}
}
}
}
}
尝试第二部分的代码。