首先解答一下这个C语言代码出错的原因:
第一个gets未定义:
出现这个错误一般是没有包含相应的头文件,或者库里没有这个函数。这里应该是没有这个函数。gets(char *dest)是一个老的库函数,采用这个函数存在越界的安全隐患。它只有一个参数,如果输入的字符个数超过dest内存空间,程序可能失败,也可能被黑客利用这个漏洞进行不正常操作。可以使用fgets(char *dest, int size, FILE *fp)代替,它可以通过第二个参数设置最大输入解决上面的问题。
第二/三个strcat参数2类型不符:
strcat的第二个参数语言char *,而调用时jiji[i]是char,可以写成&jiji[i],改完语法没有问题,逻辑要再自己评估一下。
第四个返回局部变量re:
re是lai函数内部的数组,在栈内,当函数执行完会进行释放资源。其栈内的空间可能用于它处,内容可能被改变。建议是不要返回局部变量。
以上就是这个代码语法出错的解答。
另外补充一下:
整体来看这段代码代码比较长,for循环也比较多,后续再优化一下。先实现功能再优化。下面这个代码你可以参考。
jiji[i]的类型是char,而strcat第二个参数应该是const char*当然不对
你的C语言程序我帮你改完了,你看看吧(改动的地方很多,你自己与原程序比对一下吧)
#include<stdio.h>
#include<string.h>
#define N 100
#define S 101
#define Z 26
char lai(int i){
char ch=(char)(i+65);
return ch;
}
int main(){
int i,n,ji[S][Z]={0},k,j,ch;
char s[S][N]={'\0'},r[S][N]={'\0'},b[2]={'\0'};
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%s",s[i]);
}
for(i=0;i<n;i++){
for(k=0;s[i][k]!='\0';k++){
for(ch=0;ch<Z;ch++){
if(s[i][k]==(char)(ch+'A')){
ji[i][ch]++;
}
}
}
}
for(j=0;j<n;j++){
for(i=0;i<Z;i++){
if(ji[j][i]!=0&&ji[j][i]!=1){
b[0]=(char)(ji[j][i]+48);
strcat(r[j],b);
b[0]=lai(i);
strcat(r[j],b);
}else if(ji[j][i]==1){
b[0]=lai(i);
strcat(r[j],b);
}
}
}
for(i=0;i<n;i++){
printf("%s\n",r[i]);
}
return 0;
}