P1019 [NOIP2000 提高组] 单词接龙

网址如下:P1019 [NOIP2000 提高组] 单词接龙 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

很怪,不知道该说什么

我试了题目给的第一个测试点的输入,发现输出和测试点的一样,但是还是WA

不是很懂为什么

有没有大佬帮我看一下

代码如下:

cs 复制代码
#include<stdio.h>
#include<string.h>
typedef struct Word{
    char str[101];//单词
    int m;//剩余使用次数
    int l;//单词的长度
}Word;
void dg(int len);
Word word[20];
int maxn, maxlen, n;
char c, str_m[1000];

int main(void)
{
    //输入
    scanf("%d", &n);
    for(int i = 0; i < n; i++)
    {
        scanf("%s", &word[i].str);
        word[i].m = 2, word[i].l = (int)strlen(word[i].str);
        maxlen = (maxlen > word[i].l) ? maxlen : word[i].l;
    }
    getchar(), c = getchar();
    //递归遍历找开头
    for(int i = 0; i < n; i++)
        if(c == word[i].str[0])
        {
            word[i].m--, strcpy(str_m, word[i].str);
            dg(word[i].l);
            word[i].m++;
        }
    //输出
    printf("%d", maxn);

    return 0;
}
void dg(int len)
{
    //更新最大长度
    maxn = (maxn > len) ? maxn : len;
    //指针作为比较对象
    const char * p = (maxlen <= len) ? &str_m[len - maxlen + 1] : &str_m[1];
    int tmp = (maxlen <= len) ? maxlen - 1 : len - 1;
    //遍历寻找下一个单词
    while(tmp)
    {
        for(int i = 0; i < n; i++)
        {
            if(!word[i].m || tmp >= word[i].l)  continue;
            char * t_p = strstr(word[i].str, p);
            if(t_p == word[i].str)//如果匹配对象在字符串开头部分
            {
                word[i].m--, strcpy(&str_m[len], &word[i].str[tmp]);
                dg(len + word[i].l - tmp);
                word[i].m++, str_m[len] = '\0';
            }
        }
        tmp--, p++;
    }
}

会是因为编译器不同吗?

相关推荐
LIN-JUN-WEI16 分钟前
[ESP32]VSCODE+ESP-IDF环境搭建及blink例程尝试(win10 win11均配置成功)
c语言·开发语言·ide·vscode·单片机·学习·编辑器
望获linux1 小时前
【Linux基础知识系列】第四十三篇 - 基础正则表达式与 grep/sed
linux·运维·服务器·开发语言·前端·操作系统·嵌入式软件
留不住丨晚霞2 小时前
说说SpringBoot常用的注解?
java·开发语言
hardStudy_h2 小时前
C++——内联函数与Lambda表达式
开发语言·jvm·c++
艾莉丝努力练剑2 小时前
【C语言】学习过程教训与经验杂谈:思想准备、知识回顾(三)
c语言·开发语言·数据结构·学习·算法
witton4 小时前
Go语言网络游戏服务器模块化编程
服务器·开发语言·游戏·golang·origin·模块化·耦合
枯萎穿心攻击4 小时前
ECS由浅入深第三节:进阶?System 的行为与复杂交互模式
开发语言·unity·c#·游戏引擎
Jerry Lau4 小时前
go go go 出发咯 - go web开发入门系列(一) helloworld
开发语言·前端·golang
nananaij4 小时前
【Python基础入门 re模块实现正则表达式操作】
开发语言·python·正则表达式
Micro麦可乐4 小时前
Java常用加密算法详解与实战代码 - 附可直接运行的测试示例
java·开发语言·加密算法·aes加解密·rsa加解密·hash算法