`
vcdemon
  • 浏览: 20055 次
社区版块
存档分类
最新评论
  • djx410249: 简单的自己想了几个数字测试了下,发现这个数会在经过几次跳动之后 ...
    3n+1
  • I白I: 怎么回事,好多字都卡在外面了 不显示。。。还要查看源代码看内容 ...
    3n+1

字符串的完美度

    博客分类:
  • java
阅读更多

题目详情:
我们要给每个字母配一个1-26之间的整数,具体怎么分配由你决定,但不同字母的完美度不同,

而一个字符串的完美度等于它里面所有字母的完美度之和,且不在乎字母大小写,也就是说字母F和f的完美度是一样的。

现在给定一个字符串,输出它的最大可能的完美度。

例如:dad,你可以将26分配给d,25分配给a,这样整个字符串最大可能的完美度为77。

函数头部

C
int perfect(const char *s);

C++
int perfect(const string &s);

java
public static int perfect(String s);


答题说明:
main函数用于方便自行编译,可不完成。
 
 
首先,在做题目之前,我得吐槽一个答题潜规则.
Code 1:

import java.util.Arrays;

public class Test {
    // 该数组存放字符串中某个字母出现的次数,如:array[0]表示a的个数,array[1]表示b的个数,其余依此类推
    static int[] array = new int[26];
    // 该变量存放完美度
    static int sum = 0;

    public static int perfect(String s) {
        s = s.toLowerCase();
        char[] ch = s.toCharArray();
        for (int i = 'a'; i <= 'z'; i++) {
            for (int j = 0; j < ch.length; j++) {
                if (ch[j] == i) {
                    array[i - 97]++;
                }
            }
        }
        Arrays.sort(array);
        for (int i = 0; i < array.length; i++) {
            array[i] = array[i] * (i + 1);
            sum = array[i] + sum;
        }
        return sum;
    }

    public static void main(String[] args) {
        String s = "DAD4538568&^%&^$$$*(\\][[";
        int sum = perfect(s);
        System.out.println(sum);
    }
}

 

Code 1在本地测试是正常的,但是为什么提交之后不通过呢? 这就涉及到了一个答题的潜规则:Line03-Line05是不可以定义全局变量的.
 
 
Code 2:

import java.util.Arrays;

public class Test {

    public static int perfect(String s) {
        // 该数组存放字符串中某个字母出现的次数,如:array[0]表示a的个数,array[1]表示b的个数,其余依此类推
        int[] array = new int[26];
        // 该变量存放完美度
        int sum = 0;
        s = s.toLowerCase();
        char[] ch = s.toCharArray();
        for (int i = 'a'; i <= 'z'; i++) {
            for (int j = 0; j < ch.length; j++) {
                if (ch[j] == i) {
                    array[i - 97]++;
                }
            }
        }
        Arrays.sort(array);
        for (int i = 0; i < array.length; i++) {
            array[i] = array[i] * (i + 1);
            sum = array[i] + sum;
        }
        return sum;
    }

    public static void main(String[] args) {
        String s = "DAD4538568&^%&^$$$*(\\][[";
        int sum = perfect(s);
        System.out.println(sum);
    }
}

 
像Code 2这样提交一次就可以成功通过提交了.
 
其实还有别的一些答题规则,实在是有些摸不着头脑.

分享到:
评论

相关推荐

    swift-BRStringPicker字符串选择器

    2. **自定义样式**:你可以自由设定每个字符串的颜色、字体、行间距,以及选择器的整体背景颜色,使其与你的应用界面完美融合。 3. **回调机制**:当用户选择了一个新的字符串时,BRStringPicker会通过Delegate或...

    最准确的php截取字符串长度函数

    描述部分提到了文章的目的是分享一个精确的PHP截取字符串函数,并鼓励读者在现有基础上进行改进或创新,说明作者可能对目前函数的精确度持有开放态度,并期待读者的反馈与改进。 在标签方面,除了关注PHP本身截取...

    C语言面试题.pdf

    本文总结了C语言面试题的重要知识点,涵盖了strcpy函数的实现、字符串操作、数组越界、库函数的工作方式等方面。 一、strcpy函数的实现 strcpy函数是C语言中最基本的字符串拷贝函数,但其实现却隐藏着许多玄机。...

    程序员紧急应聘试题完美解析.pdf,这是一份不错的文件

    总结来说,这份“程序员紧急应聘试题完美解析”涵盖了C/C++编程的核心知识点,包括字符串操作、内存管理和错误处理,这些都是程序员在实际工作中需要掌握的基本技能。通过分析和解决面试题,应聘者可以检验自己的...

    C/C++ 程序设计员应聘常见面试笔试试题深入剖析

    完美的实现应包括对输入参数的断言检查和对空字符串的处理。 通过分析这些面试题,不仅能够检验面试者的编程基础,还能促使他们在解决实际问题时更加注重代码的健壮性和效率。因此,对于C/C++程序员来说,不断地...

    C++精要问题

    - 4分的实现增加了`const`关键字,表明源字符串是不可修改的,提高了代码的清晰度和安全性。 - 7分的实现添加了`assert`来检查指针是否为空,增强了错误处理。 - 10分的实现不仅包含了上述所有改进,还返回了目的...

    C_C++常见面试题深入剖析

    文章中给出的完美版本`strlen`函数不仅正确地实现了长度计算,还加入了断言检查,确保传入的字符串指针非空,增加了函数的健壮性和安全性。 ### 3. 内存管理与常见陷阱 #### (1) 动态内存分配的错误示范 试题4...

    c#调用大漠插件100%完美识别文字

    7. **处理结果**:识别后的结果通常以字符串形式返回,需要进行解析和处理,如去除空格、换行等。 8. **释放资源**:最后,记得释放插件的资源,避免内存泄漏。 在这个过程中,为了达到100%的识别率,关键在于正确...

    锐商企业CMS 3.8.zip

    SEO性能出众,支持多国语言(多语种并行创作),独创的前端编辑系统(FrEE),直接在最终页面上组织创作内容,编译级主题模板机制,无需编码实现主题模板定制,支持企业授权内容保护,内建101条网站完美度指标。...

    jquery获取下拉列表的值为null的解决方法

    然而,在使用jQuery获取下拉列表(select)的值时,我们可能会遇到返回字符串“null”的情况,而不是我们期望的空值。这个问题会导致在将这个值用在其他逻辑处理(如数据库查询、条件判断等)时产生错误。 首先,...

    PCtoLCD2002软件完美版

    特别的是,PCtoLCD2002能生成中英文混合的字符串字模数据,这在处理多语言显示时尤其有用,因为它可以确保各种语言的文本在LCD屏幕上都能正确且美观地显示。 标签中的“软件/插件”表明PCtoLCD2002既可以作为一个...

    C++ 程序设计员应聘常见面试试题深入剖析

    - 4分版本添加了`const`关键字,表示源字符串不可修改,提高了函数的语义清晰度。 - 7分版本引入了`assert`,对输入参数进行非空检查,增加了函数的健壮性。 - 10分版本除了上述改进外,还返回了目的字符串的地址,...

    华为od1-5月高频机试题

    目标是找到最短的连续子串替换,使得整个字符串变成一个完美走位,即所有方向的步数相同。可以通过滑动窗口或者哈希表来找出需要替换的最小子串长度。 4. **日志采集系统**: 这涉及到实时数据处理和优化策略。...

    编程面试中排名前 10 的算法相关的概念

    #### 一、字符串处理技巧 在编程面试中,字符串处理是一个非常常见的考点。了解并熟练掌握基本的字符串操作可以帮助你更高效地解决问题。以下是一些重要的字符串操作方法: 1. **`toCharArray()`**:将字符串转换...

    100个直接可以拿来用的JavaScript实用功能代码片段(1-10)

    1、原生JavaScript实现字符串长度截取 2、原生JavaScript获取域名主机 3、原生JavaScript清除空格 4、原生JavaScript替换全部 5、原生JavaScript转义html标签 6、原生JavaScript还原html标签 7、原生JavaScript时间...

    C/C++ 程序设计员应聘常见面试试题深入剖析

    同样,对于strlen函数,一个完美的实现应当考虑字符串是否为NULL,并在计算长度时包含'\0'。 通过这样的深入剖析,不仅能够检验应聘者的编程技能,还能提升他们的思考和解决问题的能力。对于开发者而言,不断磨练...

    内存管理面试题-经典

    通过对这些面试题的分析,我们可以看到,写一个简单的strcpy函数并不是那么简单的事情,它需要对基本功的掌握,包括字符串以'\0'结尾、数组越界的敏感度、库函数strcpy的工作方式等。 知识点1: 字符串以'\0'结尾 ...

Global site tag (gtag.js) - Google Analytics