【问题标题】:Make a string Palindrome in C在 C 中创建一个字符串回文
【发布时间】:2015-01-02 11:47:58
【问题描述】:

詹姆斯找到了一封他的朋友哈利写给他女朋友的情书。詹姆斯是个恶作剧者,所以他决定插手这封信。他把信中的所有单词都变成了回文。

为此,他遵循两条规则:

(a) 他可以减少一个字母的价值,例如他可以将“d”更改为“c”,但不能将“c”更改为“d”。 (b) 为了形成回文,如果他必须反复减少一个字母的值,他可以这样做直到字母变成'a'。字母一旦更改为“a”,就无法再更改。

任何字母值的每次减少都计为一次操作。找出将给定字符串转换为回文所需的最小操作数。

输入格式 第一行包含一个整数 T,即测试用例的数量。 接下来的 T 行每行将包含一个字符串。字符串不包含任何空格。

输出格式 一行包含每个测试用例对应的最小操作数。

约束 1≤T≤10 1 ≤ 字符串长度 ≤ 104 所有字符均为小写英文字母。

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

int main() {

    /* Enter your code here. Read input from STDIN. Print output to STDOUT */ 
    int count;
    int result;
    int i,j;

    scanf("%d",&count);

    for (i = 0 ; i < count ; i++){

        result = 0;

        char * string;
        scanf("%ms",&string);

        int k = (int)strlen(string);

        printf("Length: %d\n",k);

        int l = k/2;

        printf("L is: %d\n",l);

        for ( j = 0 ; j < l ; j++){

            printf("first char is is: %c\n",string[j]);
            printf("Second char is is: %c\n",string[k-j-1]);
            printf("Current loop count: %d\n",j);

            if ( string[j] != string [k-j] ){

                int g = (int)(string[j] - string[k-j-1]);
                if ( g > 0){
                    result += g;
                }
                else{
                    result -= g;
                }

            }
            else;

        }

        printf("%d\n",result);

    }
    return 0;
}

示例输入 #00

4
abc
abcba
abcd
cba

样本输出 #00

2
0
4
2

解释

对于第一个测试用例,abc -> abb -> aba。 对于第二个测试用例,abcba 已经是回文字符串。 对于第三个测试用例,abcd -> abcc -> abcb -> abca = abca -> abba。 对于第四个测试用例,cba -> bba -> aba。

上述代码适用于给定的示例输入,但根据 hackerrank,它不是正确的。有人可以指出错误吗?

【问题讨论】:

  • 你从未初始化变量string
  • @Barmar scanf("%ms",&amp;string);。但是,如果 scanf() 失败了,那就另当别论了。
  • 这不会为字符串分配空间。 string 指向内存中的某个随机地址。
  • 啊,%ms 对我来说是新的,它是分配字符串空间的 POSIX 扩展。
  • @Barmar - 哦!对我来说也是新的;解释“&string”。

标签: c palindrome c-strings


【解决方案1】:

错误在这里:

if ( string[j] != string [k-j] ){

第二个字符应该是string[k-j-1]。比如j = 0,你应该和string[k-1]比较,比较字符串的第一个和最后一个字符。

另外,你有内存泄漏。在外循环的底部你应该这样做:

free(string);

【讨论】:

  • 该死的!我知道我会犯这样的错误。我被困在这里,谢谢你的帮助。
猜你喜欢
  • 2010-12-27
  • 2012-01-17
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-05-26
  • 2021-03-08
  • 1970-01-01
相关资源
最近更新 更多