Calling a stream in a function
Dec 9, 2012 at 9:57pm UTC  
So I am writing a very simple program that prompts a user to input a file name. Assuming file name enters exists, the program will display the largest and smallest numbers to the screen. When I run the program, the largest output is correct, but the smallest displays a number not even in the file. If I switch the order of the largest and smallest function calls, the smallest displays correctly, but the largest does not. Any help would be greatly appreciated.
1#include <iostream> 
#include <fstream> 
#include <cstdlib> 
#include <climits> 
using  namespace  std;
void  largest(ifstream& numbers, int & max);
void  smallest(ifstream& numbers, int & min);
void  output(int  max, int  min);
int  main()
{
	int  max = -INT_MAX, min = INT_MAX;
	char  file_name[16];
	cout << "Enter the file_name " ;
	cin >> file_name;
	ifstream numbers;
	numbers.open(file_name);
	if  (numbers.fail( ) )
	{    
		cout << "Input file opening failed."  << endl;
		exit(1);
	}
	largest(numbers, max);
	smallest(numbers, min);
	output(max, min);
	return  0;
}
void  largest(ifstream& numbers, int & max)
{
	int  next;
	while  (numbers >> next)
	{
		if  (next > max)
			max = next;
	}
	numbers.close();
}
void  smallest(ifstream& numbers, int & min)
{
	int  next;
	while  (numbers >> next)
	{
		if  (next < min)
			min = next;
	}
	numbers.close();
}
void  output(int  max, int  min)
{
	char  exit;
	cout << "The largest number is " 
		 << max
		 << endl
		 << "The smallest number is " 
		 << min
		 << endl
		 << endl
		 << "Enter any character to exit: " ;
	cin >> exit;
}
 
Dec 10, 2012 at 1:29am UTC  
I got it to work.
I just opened the file again between the largest and smallest functions like this:
1largest(numbers, max);
numbers.open(file_name);
smallest(numbers, min);
output(max, min);
Is this the best way to go about this, or is there a better way? FYI, I am still very much a noob at programming.
Last edited on Dec 10, 2012 at 1:46am UTC  
 
Dec 10, 2012 at 1:50am UTC  
If you close the file at the end of largest() this is the only  way to go
 
Topic archived. No new replies allowed.