EvilZone
		Programming and Scripting => C - C++ => : Lionofgod  July 19, 2011, 09:31:19 PM
		
			
			- 
				Hey, so I've been learning my c++ and I've been trying to solve a problem.
 So far I've learned about
 while, for, loops
 if,else statements
 Functions
 I guess, pretty much the basics.
 So i was presented with a problem, the problem being
 Write a program that lets the user enter any number n and then finds
 the first prime number larger than n.
 So my soloution was#include "stdafx.h"
 #include <iostream>
 #include <math.h>
 
 double square (double a) ; // square root finding function
 
 int modulus(int a, int b , double c, int d) ; // function to find whether number is prime or not
 
 using namespace std ;
 
 int main ()
 {
 int prime = 0 ;
 double n; // Number that prime number must be > than.
 double i ; //Number to test primeness on
 
 int l=2; //loop
 cout << "Please enter the value that the first prime number must be greater than! " << endl ;
 cin >> n ;
 i=n    ;
 i++; // set i greater than n
 
 while(i<n){
 modulus (i, l, n, prime) ;
 if ( prime=0){ // if modulus returns prime=0
 i++ ;    } // increase i, to run loop again, with greater number
 if (prime=1)// if modulus returns prime=1
 cout << "The number " << i << " is the first prime number after " << n << endl;
 break; // end loop as prime number is found
 
 }
 
 getchar();
 getchar();
 }
 
 
 double square (double a)
 {
 return sqrt(a);
 }
 
 int modulus (int a, int b, double c, int d) {
 for (b=2; b<=square(c) ; b++) {
 if (a%b==0){ // This would mean the number is not prime
 d=0 ;
 return d=0 ;
 }
 if (b>=square(c)) { // if b becomes equal to or greater than the number, the number would be prime
 return d=1;
 }
 
 }
 }
 
 
I've looked at this code a million times and I just cant figure out why it doesnt work?
 It builds succesfully, (just gives me a warning on conversion from double to int, which is fine)
 When i run it however, i get to the first step, entering the number which the prime number must be > than
 BUT then the program just asks me to press any key to continue and exits!
 It totally skips my loop, although the condition is already met!
 Can someone help me out here???
 
- 
				I think I see where the error is... I haven't tried it though,
 
 after your:
 
 cin>>n;
 i=n;
 i++;
 
 you say:
 while(i<n)
 "i" is never going to be less than "n" because you first made it equal to "n", then incremented it by one? Therefore your code inside the while statement is never being used. :) Hope that helps!!
 
 Edit:
 
 Also in your Modulus function, there is no need to say:
 return d=0;if you want it to return the value of d then this will do:
 return d;
 You also seem to be doing a few things that aren't really needed.. :P
 If I wasn't off on my way to work I'd stick it into a compiler and have a better look! But if your still stuck when I get in in the morning then I'll load it up and try help :P
- 
				Hey, i removed d=0 and put it as just 
 return d;but still no luck : (
 
 
- 
				Well, your square function does nothing but wrap the sqrt function so it is not needed. 
 
 Now the real problem(why it is skipping the loop) electricnoodle answered.
 
 in this code:
     cin >> n ;
 i=n    ;
 i++; // set i greater than n
 
 while(i<n){
 
 remove the i++ statement and change "while(i<n)" to "while(i<=n)"
 
 There is probably more than that but im tired right now.
- 
				Well, your square function does nothing but wrap the sqrt function so it is not needed. 
 
 Now the real problem(why it is skipping the loop) electricnoodle answered.
 
 in this code:
     cin >> n ;
 i=n    ;
 i++; // set i greater than n
 
 while(i<n){
 
 remove the i++ statement and change "while(i<n)" to "while(i<=n)"
 
 There is probably more than that but im tired right now.
 
 Okay, i did that and now when i type in a number for the first time, then i get the next number after that as a result!
 And im not typing in a prime number.
  the number 25 is the first prime number after 24 
- 
				Okay, i did that and now when i type in a number for the first time, then i get the next number after that as a result!
 And im not typing in a prime number.
 
 
 Can you post the last version of the code?
- 
				Can you post the last version of the code?
 
 yep :D
 #include "stdafx.h"
 #include <iostream>
 #include <math.h>
 
 double square (double a) ; // square root finding function
 
 int modulus(int a, int b , double c, int d) ; // function to find whether number is prime or not
 
 using namespace std ;
 
 int main ()
 {
 int prime = 0 ;
 double n; // Number that prime number must be > than.
 double i ; //Number to test primeness on
 
 int l=2; //loop
 cout << "Please enter the value that the first prime number must be greater than! " << endl ;
 cin >> n ;
 i=n    ;
 
 while(i>=n){
 modulus (i, l, n, prime) ;
 if ( prime=0){ // if modulus returns prime=0
 i++ ;    } // increase i, to run loop again, with greater number
 if (prime=1)// if modulus returns prime=1
 cout << "The number " << i << " is the first prime number after " << n << endl;
 break; // end loop as prime number is found
 
 }
 
 getchar();
 getchar();
 }
 
 
 double square (double a)
 {
 return sqrt(a);
 }
 
 int modulus (int a, int b, double c, int d) {
 for (b=2; b<=square(c) ; b++) {
 if (a%b==0){ // This would mean the number is not prime
 d=0 ;
 return d ;
 }
 if (b>=square(c)) { // if b becomes equal to or greater than the number, the number would be prime
 return d=1;
 }
 
 }
 }
 
- 
				I have not yet seen the rest of the code, but I can tell you this. If you want to know prime numbers and work with prime numbers in this, use only integer variables. Even if the input in a double, make a cast to int like this:
 
 int a;
 double b = 10.23;
 a = (int) b; //a = 10
 int a;
 double b = 10.99;
 a = (int) b; //a = 10
 (Note this is not rounding the number. If it were then in the second code a would be equal to 11)
 
- 
				(I am sorry for the double post. But I really felt it was necessary.)
 
 Ok. So a few thinks. I solved your problem, the solutions is below. But please note this:
 
 First you code is a little "missed shaped". What I mean is, the place where you put the {} signs, and some other symbols are not always the same. Even if this is not confusing for many people it is still a good programming practice to adopt an indentation style. See this page for details: http://en.wikipedia.org/wiki/Indent_style. (http://en.wikipedia.org/wiki/Indent_style.)
 
 Another think. I noticed that you had an argument in the modulus (modulus(i, l, n, prime)) function called prime. And then you had, inside that function something saying return d = 0, and then outside modulus you had an if testing if prime was equal to 0 or 1. This is a bit of a logical error. If you send prime to the function, inside modulus d will take it's value. But prime won't be altered. I hope by the alteration I made you can check the difference.
 
 Also, I had to alter the name of the function modulus to modulus2 because modulus already exists in the c++ std namespace.
 
 Happy Hacking!
 
 #include <iostream>
 #include <stdio.h>
 #include <math.h>
 
 int square (int a); // square root finding function
 
 int modulus2(int a, int c); // function to find whether number is prime or not
 
 using namespace std;
 
 int main ()
 {
 double input;
 int n; // Number that prime number must be > than.
 int i ; //Number to test primeness on
 
 cout << "Please enter the value that the first prime number must be greater than! " << endl ;
 cin >> input;
 n = (int)input;
 i= n;
 
 while(1)
 {
 if(modulus2(i, n) == 0) // if modulus returns prime=0
 i++;
 
 else if(modulus2(i, n) == 1) // if modulus returns prime=1
 {
 cout << "The number " << i << " is the first prime number after " << n << endl;
 break; // end loop as prime number is found
 }
 }
 
 getchar();
 getchar();
 }
 
 
 int square (int a)
 {
 return sqrt((double)a);
 }
 
 int modulus2(int a, int c)
 {
 for (int b=2; b<=square(c) ; b++)
 if (a%b==0) // This would mean the number is not prime
 return 0;
 return 1;
 }
- 
				(I am sorry for the double post. But I really felt it was necessary.)
 
 Ok. So a few thinks. I solved your problem, the solutions is below. But please note this:
 
 First you code is a little "missed shaped". What I mean is, the place where you put the {} signs, and some other symbols are not always the same. Even if this is not confusing for many people it is still a good programming practice to adopt an indentation style. See this page for details: http://en.wikipedia.org/wiki/Indent_style. (http://en.wikipedia.org/wiki/Indent_style.)
 
 Another think. I noticed that you had an argument in the modulus (modulus(i, l, n, prime)) function called prime. And then you had, inside that function something saying return d = 0, and then outside modulus you had an if testing if prime was equal to 0 or 1. This is a bit of a logical error. If you send prime to the function, inside modulus d will take it's value. But prime won't be altered. I hope by the alteration I made you can check the difference.
 
 Also, I had to alter the name of the function modulus to modulus2 because modulus already exists in the c++ std namespace.
 
 Happy Hacking!
 
 #include <iostream>
 #include <stdio.h>
 #include <math.h>
 
 int square (int a); // square root finding function
 
 int modulus2(int a, int c); // function to find whether number is prime or not
 
 using namespace std;
 
 int main ()
 {
 double input;
 int n; // Number that prime number must be > than.
 int i ; //Number to test primeness on
 
 cout << "Please enter the value that the first prime number must be greater than! " << endl ;
 cin >> input;
 n = (int)input;
 i= n;
 
 while(1)
 {
 if(modulus2(i, n) == 0) // if modulus returns prime=0
 i++;
 
 else if(modulus2(i, n) == 1) // if modulus returns prime=1
 {
 cout << "The number " << i << " is the first prime number after " << n << endl;
 break; // end loop as prime number is found
 }
 }
 
 getchar();
 getchar();
 }
 
 
 int square (int a)
 {
 return sqrt((double)a);
 }
 
 int modulus2(int a, int c)
 {
 for (int b=2; b<=square(c) ; b++)
 if (a%b==0) // This would mean the number is not prime
 return 0;
 return 1;
 }
 Thank you very much this will help me learn a lot :D
 I will also take a look at the indentation style you mentioned.
 karma ++ ;
 
 
- 
				karma ++ ;
 
 
 Ah! Thank you very must!!