JavaScript算法实例

博客介绍了使用JavaScript实现的多个算法任务,包括将数字转换为罗马数字、找出两数组差异、翻译二进制字符串、判断集合对象属性值真假以及计算最小公倍数等内容,聚焦于信息技术领域的算法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

将给定的数字转换成罗马数字
var bet={
 signal:['I',"II",'III','IV','V','VI','VII','VIII','IX'],
 decade:['X','XX','XXX','XL','L','LX','LXX','LXXX','XC'],
 hundred:['C','CC','CCC','CD','D','DC','DCC','DCCC','CM'],
 thousand:["M","MM","MMM"]//其他长度的数字继续编码就行
};
var betIndex=["signal","decade","hundred","thousand"];

function convert(num){  
var numLength;
var flag1=[];
var flag2=[];
 numLength=num.toString().length;
 num=num.toString();
 for(var i=0;i<numLength;i++){
   flag1.push(bet[betIndex[i]]);
 }
 flag1.reverse();
 for(var j=0;j<flag1.length;j++){
   flag2.push(flag1[j][Number(num[j])-1]);
 }  
return flag2.join("");
}

convert(3999);//return "MMMCMXCIX"

比较两个数组,然后返回一个新数组,该数组的元素为两个给定数组中所有独有的数组元素。换言之,返回两个数组的差异。
function diff(arr1, arr2) {
  var newArr = [];
  // Same, same; but different.
  for(var i=0;i<arr1.length;i++)
    {
      if(arr2.indexOf(arr1[i])==-1){
       newArr.push(arr1[i]);
      }
    }
  for(var i=0;i<arr2.length;i++)
    {
      if(arr1.indexOf(arr2[i])==-1){
       newArr.push(arr2[i]);
      }
    }  
  return newArr;
}

diff([1, "calf", 3, "piglet"], [7, "filly"]);//return [1, "calf", 3, "piglet", 7, "filly"]

传入二进制字符串,翻译成英语句子并返回。二进制字符串是以空格分隔的。
function binaryAgent(str) {
  var arr=[],decade=0x00,num=0x00,temp=[];
  arr=str.split(" ");
  for(var i=0;i<arr.length;i++){
    for(var j=0;j<8;j++){
      if(j<4&&arr[i][j]==1){
        switch (j){
          case 0:
              decade=decade+0x80;
              break;
          case 1:
              decade=decade+0x40;
              break;
          case 2:
              decade=decade+0x20;
              break;
          case 3:
              decade=decade+0x10;
              break;          
        }
      }
      if(j>3&&arr[i][j]==1){
         switch (j){
          case 4:
              num=num+0x08;
              break;
          case 5:
              num=num+0x04;
              break;
          case 6:
              num=num+0x02;
              break;
          case 7:
              num=num+0x01;
              break;          
        }
      }
    }
    temp.push(String.fromCharCode(decade+num));
    decade=0x00;num=0x00;
  }
  //return String.fromCharCode(0x6c);
  return temp.join("");
}
binaryAgent("01001001 00100000 01101100 01101111 01110110 01100101 00100000 01000110 01110010 01100101 01100101 01000011 01101111 01100100 01100101 01000011 01100001 01101101 01110000 00100001");//return "I love FreeCodeCamp!"

binaryAgent("01000001 01110010 01100101 01101110 00100111 01110100 00100000 01100010 01101111 01101110 01100110 01101001 01110010 01100101 01110011 00100000 01100110 01110101 01101110 00100001 00111111");//return   "Aren't bonfires fun!?"

如果集合(collection)中的所有对象都存在对应的属性(pre),并且属性(pre)对应的值为真。函数返回ture。反之,返回false。
function every(collection, pre) {
  // Is everyone being true?
  var result;
 result=collection.every(element=>{
     return (Object.keys(element).indexOf(pre)!=-1)&&(element[pre]);
   }                      
   );
  return result;
}

every([{"single": "yes"}], "single");//ture
every([{"user": "Tinky-Winky", "sex": "male", "age": 0}, {"user": "Dipsy", "sex": "male", "age": 3}, {"user": "Laa-Laa", "sex": "female", "age": 5}, {"user": "Po", "sex": "female", "age": 4}], "age");//false;
找出能被两个给定参数和它们之间的连续数字整除的最小公倍数。
function SmallestCommonMultiple(str){
  for(var i=str[0];i<=str[0]*str[1];i+=str[0]){
    if(i%str[1]==0){
      break;
    }
  }
  return i;
}

function smallestCommons(arr) {
  var temp=[],transArr=[];
  arr.sort((a,b)=>a-b);
  for(var i=arr[0];i<=arr[1];i++){
    transArr.push(i);
  }
  while(transArr.length!=2){
  arr=[];
  arr.push(transArr.shift());
  arr.push(transArr.shift());
  transArr.push(SmallestCommonMultiple(transArr));
  arr.sort((a,b)=>a-b);
  }
 
  return transArr[0];
  //return transArr;
}

//区间值不能太大
smallestCommons([1,24]);//return 5354228880
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值