Hello; I am new to programming, and in need of some assistance with a problem in trying to use a string... My error seems to be happening where the calculation for the next digit takes place. Any help would be greatly appreciated.
#include <iostream>
usingnamespace std;
int main() {
// define variables
int isbn;
int d1;
int d2;
int d3;
int d4;
int d5;
int d6;
int d7;
int d8;
int d9;
int d10;
//Receive values for variables
cout << "Enter the first 9 digits of an ISBN as integer:" << endl;
cout << "ISBN = ";
cin >> isbn;
//find d9, d8, d7 ... d1
d9 = isbn % 10;
isbn = isbn / 10;
d8 = isbn % 10;
isbn = isbn / 10;
d7 = isbn % 10;
isbn = isbn / 10;
d6 = isbn % 10;
isbn = isbn / 10;
d5 = isbn % 10;
isbn = isbn / 10;
d4 = isbn % 10;
isbn = isbn / 10;
d3 = isbn % 10;
isbn = isbn / 10;
d2 = isbn % 10;
isbn = isbn / 10;
d1 = isbn % 10;
d10 = ((d1 * 1) + (d2 * 2) + (d3 * 3) + (d4 * 4) + (d5 * 5) + (d6 * 6) + (d7 * 7) + (d8 * 8) + (d9 * 9)) % 11;
cout << "The ISBN is: " << d1 << d2 << d3 << d4 << d5 << d6 << d7 << d8 << d9;
if (d10 == 10) {
cout << "X ";
}
else {
cout << d10 << endl;
}
system("pause");
return 0;
}
the s.length line was meant to tell the program that the value of "s" should be 10 digits. so that when i cout the IBN, it would have all d1 - d10 when the user imputs 9 of those digits
the s.at(9) was meant to calculate the 10th digit.
so check to see if you just meant = instead of ==. This and the reverse of this are two typos that often compile but either do nothing or do the wrong thing entirely, depending on context.
if (x = y) //this is true unless y is zero. it assigns x to the value of y as a side effect, usually not intended.
if(x==y) //this is true if x and y have the same value. x is not modified.
and the reverse
x == y+2; //evaluates a temporary result of true or false and throws that result away. nothing is actually done here.
your compiler should be set to warn about these. Because it compiles and because its a common typo / mistake, compilers look for it.