我需要读取字符串(带空格)并将其反转。
首先我从控制台读取一串字符。
char array[100];
for(int i = 0; i < sizeof(array); i++)
array[i] = '0';
for(int i = 0; i < sizeof(array); i++)
cout<<array[i]<<" ";
cout<<"\n\nenter your string: ";
cin.getline(array, 100);
cout<<"\n";
for(int i = 0; i < sizeof(array); i++)
cout<<array[i]<<" ";
然后我创建并填充索引数组。 (记住空间点)
cout<<"\n\nindexes: ";
int indexes[20];
for(int i = 0; i < 20; i++)
{
indexes[i] = 0;
}
// filling the indexes array
int j = 0;
for(int i = 0; i < sizeof(array); i++)
{
if(array[i] == '0') break;
if(array[i] == ' ') indexes[j++] = i;
}
// validating indexes array
for(int i = 0; i < sizeof(indexes); i++)
{
//if(indexes[i] == 0) break;
cout<<indexes[i]<<" ";
}
这是我(我猜不聪明)algorythm的开头。我想颠倒第一个词 好像这个块从未执行过。为什么?
// first word
int j1 = indexes[0]-1;
for(int i = 0; i > indexes[0]; i++)
{
new_array[i] = array[j1-i];
cout<<"\naction\n";
}
将new_array打印到控制台:
for(int x = 0; x < sizeof(new_array); x++)
{
if(new_array[x] == '0') break;
cout<<new_array[x]<<" ";
}
结果是:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
输入你的字符串:这是我的字符串
我是什么时候0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
index:4 7 10 17 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 -858993460 -858993460 100 -85 8993460 -858993460 100 -858993460 -858993460 100 -858993460 -858993460 193628786 0 544434464 1931508077 1852404340 805314663 808464432 808464432 808464432 808464 432 808464432 808464432 808464432 808464432 808464432 808464432 808464432 808464 432 808464432 808464432 808464432 808464432 808464432 808464432 808464432 808464 432-858993460 -742139265 6421640 18244041 1 9932784 9928256 -742139185 0 0 2129 674240 -1920 570026249 0 6422528 0 6421580 0 6421712 18223374 -759898201 0 64216 48 18244541
新阵列:
为什么索引数组在零后包含这些数字?它的长度只有20 为什么不打印new_array?
我知道我的解决方案非常麻烦)
答案 0 :(得分:5)
你的直觉是对的:循环不是正在执行。问题在于:
for(int i = 0; i > indexes[0]; i++)
比较应为i < indexes[0]
。