以下代码有什么问题 1 #include <stdio.h> 2 #include <stdlib.h> 3 #include <time.h> 4 #include <string.h> 5 6 int main() 7 { 8 int n,i; 9 srand((unsigned)time(NULL)); 10 printf("请输入要抽取的假面骑士个数:"); 11 scanf("%d",&n); 12 13 char bag[10][10]; 14 char *name[]={"Ryuki","Blade","Decade","Kubuto","Den-o","Agito","Kuuga","Kiva","Hibiki","Faiz"}; 15 for(int j=0; j<n; j++) 16 { 17 bag[j][0]= *name[j]; 18 } 19 printf("\n"); 20 for(int a=0; a<n; a++) 21 { 22 printf("%s ",bag[a]); 23 } 24 25 26 27 }
时间: 2024-04-22 09:26:47 浏览: 197
C代码教程1显示#include <stdio.
这段代码存在以下问题:
1. 在循环中,你使用了变量 `j`,但是在循环之前没有为 `j` 声明,应该将 `int j=0` 放在循环之前。
2. 在循环中,你将 `name[j]` 的首字母赋值给 `bag[j][0]`,但是 `name[j]` 是一个字符串指针,而不是一个字符。应该使用 `strcpy` 函数将字符串从 `name[j]` 复制到 `bag[j]`。
3. 当抽取的假面骑士个数 `n` 大于10时,会导致数组越界。你可以考虑使用动态内存分配,或者对 `n` 进行限制。
4. 在输出 `bag` 数组的循环中,你没有在每个字符串后面添加一个空格。应该将 `printf("%s ",bag[a]);` 改为 `printf("%s ", bag[a]);`。
这些问题可能会导致程序崩溃或产生不正确的结果。建议你根据上述建议进行修改。
阅读全文