我有这段代码:
int main(){
char vector[52];
char i;
/* initialize the vector */
for (i ='a'; i < 'z'; i++){
vector[i] = i - 'a' + 1;
}
// vector is like vector['a'] = 1, vector['b'] = 2 .. vector['z'] = 26
for (i ='A'; i <= 'Z'; i++){
vector[i] = i - 'A' + 27;
}
// vector is like vector['A'] = 27, vector['B'] = 28 .. vector['z'] = 52
for (i ='a'; i <= 'z'; i++){
printf("letter %c : %d \n", i, vector[i]);
}
for (i ='A'; i <= 'Z'; i++){
printf("letter %c : %d \n", i, vector[i]);
}
return 0;
}
输出:
letter a : 1
letter b : 2
letter c : 3
letter d : 4
letter e : 5
letter f : 6
letter g : 7
letter h : 8
letter i : 9
letter j : 10
letter k : 11
letter l : 12
letter m : 13
letter n : 14
letter o : 15
letter p : 16
letter q : 17
letter r : 18
letter s : 19
letter t : 20
letter u : 21
letter v : 22
letter w : 23
letter x : 24
letter y : 25
letter z : 0
letter A : 27
letter B : 28
letter C : 29
letter D : 30
letter E : 31
letter F : 32
letter G : 33
letter H : 34
letter I : 35
letter J : 36
letter K : 37
letter L : 38
letter M : 39
letter N : 40
letter O : 41
letter P : 42
letter Q : 43
letter R : 44
letter S : 45
letter T : 46
letter U : 47
letter V : 48
letter W : 49
letter X : 50
letter Y : 51
letter Z : 52
*** stack smashing detected ***: ./a.out terminated
======= Backtrace: =========
/lib/i386-linux-gnu/libc.so.6(__fortify_fail+0x50)[0xc25df0]
/lib/i386-linux-gnu/libc.so.6(+0xe5d9a)[0xc25d9a]
./a.out[0x8048547]
[0x343332]
======= Memory map: ========
00110000-0012a000 r-xp 00000000 08:01 131939 /lib/i386-linux-gnu/libgcc_s.so.1
0012a000-0012b000 r--p 00019000 08:01 131939 /lib/i386-linux-gnu/libgcc_s.so.1
0012b000-0012c000 rw-p 0001a000 08:01 131939 /lib/i386-linux-gnu/libgcc_s.so.1
00a19000-00a1a000 r-xp 00000000 00:00 0 [vdso]
00aa4000-00ac0000 r-xp 00000000 08:01 131898 /lib/i386-linux-gnu/ld-2.13.so
00ac0000-00ac1000 r--p 0001b000 08:01 131898 /lib/i386-linux-gnu/ld-2.13.so
00ac1000-00ac2000 rw-p 0001c000 08:01 131898 /lib/i386-linux-gnu/ld-2.13.so
00b40000-00c9a000 r-xp 00000000 08:01 131911 /lib/i386-linux-gnu/libc-2.13.so
00c9a000-00c9b000 ---p 0015a000 08:01 131911 /lib/i386-linux-gnu/libc-2.13.so
00c9b000-00c9d000 r--p 0015a000 08:01 131911 /lib/i386-linux-gnu/libc-2.13.so
00c9d000-00c9e000 rw-p 0015c000 08:01 131911 /lib/i386-linux-gnu/libc-2.13.so
00c9e000-00ca1000 rw-p 00000000 00:00 0
08048000-08049000 r-xp 00000000 08:01 40062 /home/valter/Documents/Complexidade/recursivo/a.out
08049000-0804a000 r--p 00000000 08:01 40062 /home/valter/Documents/Complexidade/recursivo/a.out
0804a000-0804b000 rw-p 00001000 08:01 40062 /home/valter/Documents/Complexidade/recursivo/a.out
0846f000-08490000 rw-p 00000000 00:00 0 [heap]
b7772000-b7773000 rw-p 00000000 00:00 0
b7782000-b7785000 rw-p 00000000 00:00 0
bfa50000-bfa71000 rw-p 00000000 00:00 0 [stack]
Aborted
我不明白为什么要提供此错误消息。 我应该有这样的矢量:
vector['a'] = 0, vector['b'] = 1, .., vector['z'] = 26, vector['A'] = 27, vector['B'] = 28, .., vector['Z'] = 52
我知道我有这个载体,但错误随之而来。 怎么解决这个问题?
答案 0 :(得分:6)
因为'Z'不等于'z'。
'Z'等于90,你的矢量只有52个元素。你的最高指数是51,所以你基本上超出了界限!
例如,当你这样做时
for (i ='A'; i <= 'Z'; i++)
{
vector[i] = i - 'A' + 27;
}
这是您的第一次迭代:
vector[65] = 65 - 65 + 27; // <-- Wrong index !
答案 1 :(得分:2)
for (i ='A'; i <= 'Z'; i++){
vector[i] = i - 'A' + 27;
}
不按照您的想法行事。 'A'
表示字符A
的ASCII值为65;您的索引立即超出范围。
答案 2 :(得分:1)
char vector[52];
因此,vector
的可访问索引是0到51.但是 -
for (i ='A'; i <= 'Z'; i++) // 'A' = 65 and 'Z' = 90
{
printf("letter %c : %d \n", i, vector[i]);
}
向量上没有这样的索引,结果超出边界异常。
答案 3 :(得分:1)
char vector[52];
for (i ='a'; i < 'z'; i++){
vector[i] = i - 'a' + 1;
}
'a'是97.你的阵列只有52长。你几乎用你的第一个可执行语句吹了数组。
我怀疑你的意思是说
vector[i-'a] = something;
(虽然我不太确定“某事”可能是什么。)
答案 4 :(得分:0)
首先,请注意:您的第一个for循环还需要包含'z'。因此:
for (i ='a'; i <= 'z'; i++){
在C中,数组不是映射从任何值到任何值。它们只是一个数组(或一个连续的列表),从索引0开始。当你说
时char vector[52];
表示你有一个大小为52的数组。数组的有效索引是0到51.但是,当你写一个像'a'
这样的字符时,它实际上只是一个数字,它是字符的ascii代码{ {1}}(即0x61,即61 hex)。您使用的最高索引是a
,即122.因此,您的数组需要索引122有效,因此大小必须至少 123。
所以你的代码就像这样:
'z'
此外,你的问题也存在矛盾。你先说你有:
int main(){
char vector[123];
char i;
/* initialize the vector */
for (i ='a'; i <= 'z'; i++){
vector[i] = i - 'a' + 1;
}
// vector is like vector['a'] = 1, vector['b'] = 2 .. vector['z'] = 26
for (i ='A'; i <= 'Z'; i++){
vector[i] = i - 'A' + 27;
}
// vector is like vector['A'] = 27, vector['B'] = 28 .. vector['z'] = 52
for (i ='a'; i <= 'z'; i++){
printf("letter %c : %d \n", i, vector[i]);
}
for (i ='A'; i <= 'Z'; i++){
printf("letter %c : %d \n", i, vector[i]);
}
return 0;
}
然后你说:
我应该有这样的矢量:
// vector is like vector['a'] = 1, vector['b'] = 2 .. vector['z'] = 26
如果您想让vector['a'] = 0, vector['b'] = 1, .., vector['z'] = 26, vector['A'] = 27, vector['B'] = 28, .., vector['Z'] = 52
从0开始而不是1,则应将公式从vector['a']
更改为vector[i] = i - 'a' + 1;