My code basically is to list ASCII codepoints of a string that is input, my following code is simple, here:
#include <iostream>
#include <string.h>
using namespace std;
int main() {
char str[20];
int result[20];
cin >> str;
for(int i = 0; i != strlen(str); i++) {
result[i] = (int)i;
}
for(int i = 0; i != 20; i++)
cout << result[i] << ", ";
}
when I run it, no matter what the input it outputs a pile of gibberish like undefined memory like so:
0, 1, 2, 3, 4, 5, 1, -1217349408, -1220040795, -1220041307, -1076427112, 134514781, -1218903292, 134519344, -1076427096, 134514004, -1217411568, 134519344, -1076427048, 134514681,
Am I missing something simple in how I append each integer to the array?
Just note this is a simple example, my input will not be larger than 20 characters.
EDIT Typo in my result.. cin>>result was cin>>str
This loop will iterate a number of times equal to the length of ‘str’. That is, it will iterate once for each character in ‘str’, and stop at the ‘null terminator’ (char value of 0) which is how c strings are ended. In each loop, the value of ‘i’ is the loop number, starting at 0 – and this is the value you assign to that index in the results array.
So for example, for a string of length 5, you will assign the values ‘0, 1, 2 ,3, 4’ to the result array at those indexes, respectively. The other values in the result array are not assigned – and so could hold any value (generally, whatever was in that bit of memory before you started using it). If your string is longer than 20 characters, you’re in trouble, because you will start trying to access the array at index 20 and beyond, which is not memory that belongs to your program.
This loop prints out all the values in the ‘result’ array, from the value at index 0 to the value at index 19:
So it will print the initialised values, and, if the string was less than 20 characters long, the uninitialised values as well.
At a minimum, to start getting anything like the results you’re after, you want to change
to
but as mentioned by others, and to escape some of the memory access issues I mentioned above, it would be much better if you use an iterator to get the character values.