• Weekly 5


    Algorithm

    1.Roman to Integer

    • What 罗马数字转为整数

    • How 不同的字母对应不同的数字,然后因为I can be placed before V (5) and X (10) to make 4 and 9. X can be placed before L (50) and C (100) to make 40 and 90.
      C can be placed before D (500) and M (1000) to make 400 and 900. 所以从后向前判断,如果I,X,C大于指定的值这时候就不是加而是减去对应的数字了。

    • Key Codes

    class Solution {
        public int romanToInt(String s) {
             int res = 0;
            for (int i = s.length() - 1; i >= 0; i--) {
                char cur = s.charAt(i);
                switch (cur) {
                    case 'I':
                        res += (res >= 5) ? -1 : 1;
                        break;
                    case 'V':
                        res += 5;
                        break;
                    case 'X':
                        res += (res >= 50) ? -10 : 10;
                        break;
                    case 'L':
                        res += 50;
                        break;
                    case 'C':
                        res += (res >= 500) ? -100 : 100;
                        break;
                    case 'D':
                        res += 500;
                        break;
                    case 'M':
                        res += 1000;
                        break;
                }
            }
            return res;
        }
    }
    

    Review

    ONE DAY AT AMAZON

    • What 在 Amazon 仓库工作了一天的体验

    • How
      本文详细记录了一个人从广播里听到Amazon仓库工人的招聘广告,从面试、到培训、再到工作的流程,惊叹于Amazon帝国之高效、规模之大。第二天,立刻买了Amazon股票。
      仓库工人有日班与夜班;日班早上6点半到晚上6点半,中间有30分钟吃午饭,以及两个15分钟可以休息。日班时薪$10.53,夜班时薪多$0.35。仓库工人经常偷东西,偷最多的是避孕套。每个工人平均每天步行13 mile(20.9公里)。有一个小时的竞争机制,最高效的2个工人,奖励$10。

    Tip

    • What 工具类必须添加私有构造器

    • How
      私有构造器,就是用private关键字声明的构造器。与一般公有构造器最大的区别在于,其访问权限是private,于是它只能被包含它的类自身所访问,而无法在类的外部调用,故而可以阻止对象的生成。所以,如果一个类只有一个私有构造器,而没有任何公有构造器,是无法生成任何对象的。
      那么无法生成对象的带有私有构造器的类究竟有什么作用呢?这样的类在实际应用中最常用的是作为工具类,如字符串的验证、枚举转换之类的,通常只做成静态接口被外部调用即可。这里先插入一点关于静态方法的说明。静态方法是用static关键字声明的方法,可以用类来直接调用而无需用从类中实例化出来的具体对象来调用,因此这样的方法也被称为类方法。static方法只能访问类中的static字段和其他的static方法,这是因为非static成员必须通过对象的引用来访问。
      举一个例子:
      public class A{
      private A(){} ///私有构造类,阻止实例的生成
      public static bool validataString(String str);
      }
      那么在外部使用的时候,只需要通过类名,而不是对象实例来调用validataString方法,如A.validataString(str);可以直接调用此方法。阻止生成对象可以防止不可预期的结果。

    Share

    关于hashCode方法的作用

  • 相关阅读:
    -1%256的值是多少?
    Glut,程序的基本架构
    剑指offer:数值的整数次方
    剑指offer:二进制中1的个数
    剑指offer:斐波那契数列的应用
    剑指offer:斐波那契数列
    剑指offer:旋转数组中的最小数字
    弱智的grub消除法
    POJ 3126 Prime Path
    HDU 1426 Sudoku Killer
  • 原文地址:https://www.cnblogs.com/cmh1111/p/10186637.html
Copyright © 2020-2023  润新知