-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtimber_auction_bruteforce.cpp
84 lines (78 loc) · 2.56 KB
/
timber_auction_bruteforce.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <fstream>
using namespace std;
//Function containing the brute force algorithm to produce answer
void executeAlgorithm(long long int **plotPoints,long long int numberOfInputPlots,int **timberForest,int rows,int columns){
//Variables to access each index of given pair of points
long long int x1;
long long int y1;
long long int x2;
long long int y2;
//for loop for calculating sum of the volume of trees in every given rectangular pieces of land
for(long long int i = 0; i < numberOfInputPlots; i++){
x1 = plotPoints[i][0];
y1 = plotPoints[i][1];
x2 = plotPoints[i][2];
y2 = plotPoints[i][3];
long long int answer = 0;
//Checking bad inputs
if((x1 > x2 || y1 > y2) || (x1 <= 0 || x2 <= 0 || y1 <= 0 || y2 <= 0) || (x1 > rows || x2 > rows || y1 > columns || y2 > columns)){
cout << "Wrong input plot points!" << endl;
}
else{
//updating the sum of the volume of trees in given rectangular piece of land
for(long long int i = x1 - 1; i < x2; i++){
for(long long int j = y1 - 1; j < y2; j++){
answer = answer + timberForest[i][j];
}
}
//printing the required sum
cout << answer << endl;
}
}
}
//Main function
int main(int argc,char *argv[]){
//Variables
int **timberForest = NULL; //Given timber forest - 2d array
int rows; //Number of rows
int columns; //Number of columns
long long int numberOfInputPlots; //Number of given pair of plot points
long long int **plotPoints = NULL; //Given pair of plot points - 2d array
//Taking input from given input file using command line and storing the input
ifstream fileIn(argv[1]);
fileIn >> rows >> columns;
timberForest = new int*[rows];
for(int i = 0; i < rows; i++){
timberForest[i] = new int[columns];
int value = 0;
for(int j = 0; j < columns; j++){
fileIn >> value;
timberForest[i][j] = value;
}
}
fileIn >> numberOfInputPlots;
if(numberOfInputPlots > 0){
plotPoints = new long long int*[numberOfInputPlots];
for(long long int i = 0; i < numberOfInputPlots; i++){
plotPoints[i] = new long long int[4];
long long int value = 0;
for(long long int j = 0; j < 4; j++){
fileIn >> value;
plotPoints[i][j] = value;
}
}
//Calling the required function for producing answer when given the input
executeAlgorithm(plotPoints,numberOfInputPlots,timberForest,rows,columns);
}
else if(numberOfInputPlots == 0){
//Nothing is printed
}
else{
cout << "Wrong input!" << endl;
}
fileIn.close();
return 0;
}