给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/binary-search
示例 1:
输入:nums
= [-1,0,3,5,9,12],target
= 9 输出: 4 解释: 9 出现在nums
中并且下标为 4
//C++实现
#include<iostream>
#include<vector>
using namespace std;int search(vector<int>num,int aim) {
int left = 0;
int len = sizeof(num) / sizeof(num[0]);
int right = len - 1;
while (left <= right)
{
int middle = left+ (right-left)/ 2;
if (aim == num[middle]) {
cout << middle;
return middle;
break;
}
else if (aim < num[middle]) right = middle - 1;
else left = middle + 1;
}
}
int main() {
vector<int>num = { 0,1,3,5,9,12 };
int aim = 9;
search(num, aim);
return 0;
}
//C语言实现
#include<stdio.h>
int nums[10];
int size = sizeof(nums) / sizeof(nums[0]);//记录数组大小。int Search(int nums[], int size, int target) {
int left = 0;
int right = size - 1;while (left <= right) {
int mid = left + (right - left) / 2; //防止溢出,实际数据是一样的。int midnums = nums[mid];
if (midnums < target) {
left = mid + 1;
}
else if (midnums > target) {
right = mid - 1;
}
else
return mid;
}
return -1;
}int main() {
int target = 0;
printf("请输入数组:");
for (int i = 0; i <10; i++) {
scanf_s("%d", &nums[i]);
}
printf("输入目标:");
scanf_s("%d", &target);
printf("%d",Search(nums, size, target));
return 0;
}
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。
不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。
元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/remove-element
输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = [2,2,3,3] 或 nums = [2,2,0,0],也会被视作正确答案。
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/remove-element
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
int delde(vector<int>num, int aim) {
int size = num.size();
for (int i = 0; i < size; i++) {
if (num[i] == aim) {
for (int j = i + 1; j < size; j++) {
num[j - 1] = num[j];
}
i--;
size--;
}
}
}