首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对词典中的用户输入进行排序,返回记忆字符?

对词典中的用户输入进行排序,返回记忆字符?
EN

Stack Overflow用户
提问于 2016-11-23 22:10:41
回答 1查看 173关注 0票数 0

我试图按字母顺序排序用户输入,最多为10,000字,最长为25字。我使用“停止”过早地结束用户输入,这使我遇到了一些问题。当我尝试输入hello时,当前程序的输出如下

代码语言:javascript
复制
 ▒l▒
0▒l▒
A{▒
e▒



▒&
▒▒
▒▒
▒▒
▒▒
▒l▒
▒l▒
▒▒;
▒Se▒
▒
▒
▒
▒





▒!
Ќl▒
▒
▒
▒
▒.X

▒

我假设这与我的内存分配有关,但我不太确定,也找不到一些关于这个问题的答案。任何帮助都将不胜感激,下面是我的代码(尽管忽略小写指针,仍在努力使输出变为小写!)

代码语言:javascript
复制
#include<stdio.h>
#include <string.h>

//for using tolower
#include <ctype.h>
int main() {
    int i, k, j;
    char abc[25];
    const char *stop = "stop";
    char *p; //using for lowercase
    //using 2d array for max of 10,000 words, max size of words 25
    char str[10000][25], temp[25];

    printf("Enter up to 10000 words, type stop to enter the current words:\n");
    while (strncmp(abc, "stop", 5) != 0) {
        scanf("%s", abc);
    }
        //for (i = 0; i < 10000; ++i)
            //scanf("%s[^\n]", str[i]);

        for (i = 0; i < 10000; ++i)
            for (k = i + 1; k < 10000; ++k) {
                //comparing two strings using strcmp() function is used
                //using strcpy() to copy string to a temp
                if (strcmp(str[i], str[k]) > 0) {
                    strcpy(temp, str[i]);
                    strcpy(str[i], str[k]);
                    strcpy(str[k], temp);
                }
            }

        //using pointer to converting to lowercase
        //src: https://www.daniweb.com/programming/software-development/threads/57296/how-does-one-tolower-an-entire-string
        for (p = str; *p != '\0'; p++)
            *p = (char) tolower(*p);

        //printing words in lexi order
        printf("\nWords in lexicographical order: \n");
        for (i = 0; i < 10000; ++i) {
            puts(str[i]);
        }
        printf("WARNING: Words longer than 25 in length were ignored. \n");

        return 0;

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-11-23 23:58:04

该守则存在以下严重问题:

  • 字符串的str数组未初始化。它可能包含完整的垃圾,包括没有空终止符的字符串。
  • 稍后的语句遍历所有这些垃圾字符串,这些字符串(通常情况下)的结尾可能不太好.
  • 您的“下降”循环,因为您不处理字符串数组,就好像它是一个单独的字符串。
  • 您在一个临时变量中读取了很多字符串,但是您不会对它们执行任何操作。

要解决这个问题,您需要跟踪数组中的项数,并且只遍历有效的字符串:

代码语言:javascript
复制
int n=0;
while (scanf("%24s", abc)>0 && strncmp(abc, "stop", 5) != 0) {
    strncpy (str[n++], abc, 25); 
}

for (i = 0; i < n; ++i)
     for (k = i + 1; k < n; ++k) {
         ...
     }
     ...
}
for (i =0; i<n; i++) 
    for (p = str[i]; *p != '\0'; p++)
        *p = (char) tolower(*p);
...
for (i = 0; i < n; ++i) {
        puts(str[i]);
}
...

这里是一个在线演示

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40774974

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档