javascript: 合并数组
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0,maximum-scale=1.0,minimum-scale=1.0,user-scalable=no">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>semd mail demo</title>
<meta name="Description" content="geovindu,涂聚文,Geovin Du"/>
<meta name="Keywords" content="geovindu,涂聚文,Geovin Du"/>
<meta name="author" content="geovindu,涂聚文,Geovin Du"/>
<script type="text/javascript" src="js/jquery-3.6.0.js"></script>
<script src="Bootstrap/3.3.7/js/bootstrap.min.js"></script>
<link href="Bootstrap/3.3.7/css/bootstrap.css" rel="stylesheet">
<script type="text/javascript">
// 1.2 空间复杂度 来源: JavaScript算法 作者: 司徒正美,李晓晨著,人民邮电出版社,2023
// ,空间复杂度(space complexity)是对一个算法在运行过程中临时占用存储空间大小的量度。
// 给定一个整数数组nums和一个整数目标值target,请你在该数组中找出“和”为目标值target的那两个整数,并返回它们的数组下标
// 方法一:暴力枚举 时间复杂度为O(n2) 空间复杂度为O(1) 采用“就地”存储
var nums=[4,0,2,9];
var target=[4];
function twoSum(nums, target) {
console.log(nums);
console.log(target);
for (let i = 0; i < nums.length; i++) {
for (let j = i + 1; j < nums.length; j++) {
if (target - nums[i] === nums[j]) {
console.log(nums[i]);
return [i, j];
}
}
}
console.log("No two sum1 solution");
};
//var twoSum =
var sum1=twoSum(nums, target);
console.log("数:"+sum1);
// 方法二:散列表 散列表进行元素存储 消耗的空间复杂度为O(n) 时间复杂度的消耗,此处为O(n)。
//var twoSum2 =
function twoSum2(nums, target) {
console.log(nums);
console.log(target);
var map = new Map();
for (let i = 0; i < nums.length; i++) {
let complement = target - nums[i];
if (map.has(complement)) {
console.log(i);
return [map.get(complement), i];
}
map.set(nums[i], i);
}
console.log("No two sum2 solution");
};
//var twoSum2=
var sum2=twoSum2(nums, target);
console.log("数:"+sum2);
var src = [1,1,2,1,4,1,3,5,7,9];
var dest = [2,4,6,8,10,12];
function mergeArray(src, dest, n, m) {
var indexOfNew = n + m - 1; // 新数组的末位索引
var indexOfSrc = n - 1; // src有效元素的末位索引
var indexOfDest = m - 1; // dest有效元素的末位索引
// 当dest全部扫描完成,元素全部插入src,剩余src元素不需要移位操作
// 当src全部遍历完成,但dest仍有元素时,只需要操作dest即可,此时src下标已达最小值0
while (indexOfDest >= 0) {
if (indexOfSrc >= 0) {
// 将src或dest中较大的元素放入src的后几位中去
if (src[indexOfSrc] >= dest[indexOfDest]) {
src[indexOfNew] = src[indexOfSrc];
--indexOfNew;
--indexOfSrc;
} else {
src[indexOfNew] = dest[indexOfDest];
--indexOfNew;
--indexOfDest;
}
} else { // 如果dest比较长,那么挪动dest到indexOfNew位置上
src[indexOfNew] = dest[indexOfDest];
--indexOfNew;
--indexOfDest;
}
}
}
mergeArray(src,dest,10,6);
console.log("合并的数组:"+src);
</script>
</head>
<body>
<form>
<div class="form-group">
<label for="exampleFormControlInput1">Email address</label>
<input type="email" class="form-control" id="exampleFormControlInput1" placeholder="geovindu@jw28.com">
</div>
<div class="form-group">
<label for="exampleInputName">Name</label>
<input type="text" class="form-control" id="exampleInputPassword1" placeholder="enter name">
</div>
<div class="form-group">
<label for="exampleFormControlSelect1">Example select</label>
<select class="form-control" id="exampleFormControlSelect1">
<option>Mr.</option>
<option>Ms</option>
</select>
</div>
<div class="form-group" style="display:none;">
<label for="exampleFormControlTextarea1">内容</label>
<textarea class="form-control" id="exampleFormControlTextarea1" rows="3"></textarea>
</div>
<button type="submit" class="btn btn-primary">Send Mail</button>
</form>
</body>
</html>
哲学管理(学)人生, 文学艺术生活, 自动(计算机学)物理(学)工作, 生物(学)化学逆境, 历史(学)测绘(学)时间, 经济(学)数学金钱(理财), 心理(学)医学情绪, 诗词美容情感, 美学建筑(学)家园, 解构建构(分析)整合学习, 智商情商(IQ、EQ)运筹(学)生存.---Geovin Du(涂聚文)
浙公网安备 33010602011771号