我正在尝试创建一个程序,它将 vector 1 ('V1') 中的 3 个不相等的值相乘,然后写入 vector 2 ('V2')。我正在使用 3 个“for”循环和一个计算 vector 2 的值的整数。但是程序会跳过“if”语句。
#include <vector>
#include<fstream>
#include<iostream>
#include <algorithm>
using namespace std;
void earase(vector<int> V2, unsigned int z){
V2.erase(V2.begin() + z);
}
void main(){
unsigned int N;
unsigned int z = 0;
vector<int> V1;
vector<int> V2;
int input;
ifstream file1;
file1.open("input.txt");
file1 >> N;
for (unsigned int i = 0; i < N; i++){
file1 >> input;
V1.push_back(input);
}
file1.close();
for (unsigned int i = 0; i < V1.size(); i++){
for (unsigned int j = 0; j < V1.size(); j++){
for (unsigned int k = 0; k < V1.size(); k++){
V2.push_back(V1[i] * V1[j] * V1[k]);
if (i == j || i == k || j == k || (i == k ) && k==j)
{
void earase(vector<int> V2, unsigned int z);
}
z++;
}
}
}
sort(V2.begin(), V2.end());
ofstream file2;
file2.open("output.txt");
file2 << V2.back();
file2.close();
}
这里是input.txt文件
4
1 2 3 4
完成后,程序对 vector 2 进行排序,并将 vector 2 中的最后一个数字写入“output.txt”,但它写入的值只有在将 vector 1 的相同值相乘 3 次时才会出现。
我认为问题出在“if”语句和“z”整数中,是否有更有效的方法来做到这一点?
最佳答案
不相等的位置是微不足道的,不需要测试(假设你只想要每个组合一次):
for (unsigned int i = 0; i < V1.size(); i++){
for (unsigned int j = 0; j < i; j++){
for (unsigned int k = 0; k < j; k++){
V2.push_back(V1[i] * V1[j] * V1[k]); } } }
如果出于某种原因,您想要多次组合所有每个组合(就好像您已经遍历了所有 N 个立方可能性,只跳过重复的位置)只需通过上述简单方法并多次推送每个组合。
关于c++ - 程序似乎跳过了 'if' 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34187512/