|  | 
 
| 
#include<stdio.h>
x
马上注册,结交更多好友,享用更多功能^_^您需要 登录 才可以下载或查看,没有账号?立即注册  #include<string.h>
 void main()
 {
 char str1,str2;
 scanf("%s %s",&str1,&str2);
 int length1=strlen(str1);
 int length2=strlen(str2);
 printf("%d %d",length1,length2);
 if(length1>length2){
 printf("%s","两者长度相等");
 }
 else{
 if(length1>length2){
 printf("%s",str1);
 }
 else{
 printf("%s",str2);
 }
 }
 char add2;
 strcat(add2,str1);
 strcat(add2,str2);
 printf("%s",add2);
 strcpy(str1,str2);
 printf("%s",str1);
 }
 
你的代码存在多个问题,导致了没有正确的输出。以下是一些主要问题及其解决方法: 
1. **字符数组声明错误**:`char str1,str2;` 应该改为 `char str1[100], str2[100];` 来确保有足够的空间存储输入的字符串。
 
2. **函数参数类型错误**:`scanf("%s %s", &str1, &str2);` 中的 `&` 应该去掉,改为 `scanf("%s %s", str1, str2);` 因为数组名本身就是地址。
 
3. **`strlen` 使用错误**:虽然这部分是正确的,但确保 `str1` 和 `str2` 是合法的字符串。
 
4. **条件判断逻辑重复**:`if(length1>length2)` 条件判断重复,需要修正。
 
5. **字符数组初始化错误**:`char add2;` 应该改为 `char add2[200];` 并在使用前初始化,例如 `add2[0] = '\0';`。
 
6. **字符串函数错误**:`strcat` 和 `strcpy` 使用时目标和源的位置写错及未初始化目标数组。
 
这是修正后的代码:
 复制代码#include<stdio.h>
#include<string.h>
void main() {
    char str1[100], str2[100];
    scanf("%s %s", str1, str2);
    int length1 = strlen(str1);
    int length2 = strlen(str2);
    
    printf("%d %d\n", length1, length2);
    
    if(length1 == length2) {
        printf("两者长度相等\n");
    } else if(length1 > length2) {
        printf("%s\n", str1);
    } else {
        printf("%s\n", str2);
    }
    char add2[200] = ""; // 初始化空字符串
    strcat(add2, str1);
    strcat(add2, str2);
    
    printf("%s\n", add2);
    strcpy(str1, str2);
    printf("%s\n", str1);
}
注意事项: 
- 确保字符数组大小足够大,以避免溢出。 
- 初始化合适的初始值,例如将 `add2` 初始化为空字符串。
 
用这些改动来使程序能够正确运行并输出预期结果。
 
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 | 
 |