鱼C论坛

 找回密码
 立即注册
查看: 46|回复: 1

[已解决]输入后没有输出

[复制链接]
发表于 5 天前 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
#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);       
}
最佳答案
5 天前
你的代码存在多个问题,导致了没有正确的输出。以下是一些主要问题及其解决方法:

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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 5 天前 | 显示全部楼层    本楼为最佳答案   
你的代码存在多个问题,导致了没有正确的输出。以下是一些主要问题及其解决方法:

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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-21 21:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表