题解 | #查找兄弟单词#

查找兄弟单词

http://www.nowcoder.com/practice/03ba8aeeef73400ca7a37a5f3370fe68

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

static char g_input[1003][11]; /* 1000 为匹配字符串,1001 和 1002 为临时转换匹配字符串 */
int main(void)
{
    int inNum, match, len;
    while(scanf("%d", &inNum) != EOF) {
        for (int i = 0; i < inNum; i++) scanf("%s", g_input[i]);
        scanf("%s%d", g_input[1000], &match);
        for (int i = 0, len = strlen(g_input[1000]); i < inNum; i++) {
            if ((strcmp(g_input[i], g_input[1000]) == 0) || (strlen(g_input[i]) != len)) { /* same or not len match. */
                strcpy(g_input[i--], g_input[--inNum]); continue; /* delete not match */
            }

            strcpy(g_input[1001], g_input[i]); qsort(&g_input[1001], strlen(g_input[1001]), sizeof(char), strcmp);
            strcpy(g_input[1002], g_input[1000]); qsort(&g_input[1002], strlen(g_input[1002]), sizeof(char), strcmp);
            if (strcmp(g_input[1001], g_input[1002]) != 0) strcpy(g_input[i--], g_input[--inNum]); /* del not match */
        }

        qsort(g_input, inNum, sizeof(g_input[0]), strcmp);
        printf("%d\n", inNum); if (inNum >= match) printf("%s\n", g_input[match - 1]); /* print result */
    }
}
全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
lllllkin:感觉可以精简到一页简历,有些排版感觉不是必须的。 时间线越早的,你自己越熟悉的放前面。描述可以更精简些,一些问题解决感觉可以不用写具体技术栈,卖个关子,等面试官问。
点赞 评论 收藏
分享
评论
点赞
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务