美文网首页
[8kyu]Welcome!

[8kyu]Welcome!

作者: 君肄塵 | 来源:发表于2017-06-26 18:19 被阅读23次

    该算法题来自于 codewars【语言: javascript】,翻译如有误差,敬请谅解~

    • 场景

    您所在公司的广告已告知营销部门,公司的网站在斯堪的纳维亚和周边国家拥有大量访客。市场部门认为在访客访问网站时,用访客自己的语言欢迎该访客,能够提高用户体验。幸运的是,你已经使用了一个API来检测用户的位置,所以你只需要根据用户位置返回对应的问候语即可。

    • 任务
      • 可以将各种语言存储到数据库中(例如对象)。语言列在下面,您可以复制粘贴!
      • 写一个函数,它接受一个参数'language'(总是一个字符串)
        1. 如果语言在数据库的话,返回一个问候语
        2. 如果语言不在数据库中,或者输入无效,则应默认为英文。
    • 数据库
    const database= {
        english: 'Welcome',
        czech: 'Vitejte',
        danish: 'Velkomst',
        dutch: 'Welkom',
        estonian: 'Tere tulemast',
        finnish: 'Tervetuloa',
        flemish: 'Welgekomen',
        french: 'Bienvenue',
        german: 'Willkommen',
        irish: 'Failte',
        italian: 'Benvenuto',
        latvian: 'Gaidits',
        lithuanian: 'Laukiamas',
        polish: 'Witamy',
        spanish: 'Bienvenido',
        swedish: 'Valkommen',
        welsh: 'Croeso'
    };
    
    • 可能的无效输入包括:
    IP_ADDRESS_INVALID - not a valid ipv4 or ipv6 ip address
    IP_ADDRESS_NOT_FOUND - ip address not in the database
    IP_ADDRESS_REQUIRED - no ip address was supplied
    

    • 解答
    • 其一
    function greet (language) {
          let keys = Object.keys(database);
          const index = keys.indexOf(language);
          const greetStr = index > -1 ? database[keys[index]] : database.english;
          return greetStr ;
    }
    
    • 其二
    const greet = (language) => { 
          return database[language] || database['english'];
    }
    
    • 其三
    function greet (language) {
          return database[language] ? database[language] : 'Welcome'
    }
    
    • 其四
    function greet (language) {
          var langArry = Object.keys(database)
          for( var i=0; i < langArry.length; i++) {    
            if(language === langArry[i]) {
              return langs[langArry[i]]
            }
          }
          return 'Welcome'
    }
    
    • 其五
    function gree t(language) {
          for (var prop in database) {
            if(prop == language) {
              return database[prop];
            }
          }
          return database['english'];
    }
    

    相关文章

      网友评论

          本文标题:[8kyu]Welcome!

          本文链接:https://www.haomeiwen.com/subject/eysjcxtx.html