27. 移除元素(三种思路: C实现)

题目

题目链接:
27. 移除元素

在这里插入图片描述
在这里插入图片描述


思路1–暴力遍历

直接一个循环遍历nums数组每个元素;
再对每个元素判断是否和val相等;
相等就把后面的元素往前移动覆盖它,已达到删除val的目的;
注意:移除元素后,要对数组元素个数-1,numsSize-1;同时,还要对第一层的for循环遍历的i做i–,因为元素移动覆盖时候位置发生变化


时间赋值度O(n2);


代码实现:

int removeElement(int* nums, int numsSize, int val)

{
    int temp = numsSize ; //临时保存变量,返回时候要用
	int count = 0; //统计移除元素的个数
	for(int i = 0;i <numsSize;i++){		
		if(val == nums[i]){
			count++;
			for(int j = i;j<numsSize -1;j++){
				nums[j] = nums[j+1];				
			}
            numsSize--;
            i--; //由于元素都是往前移动了,所以i也要--
		}
        
	}
	return temp - count;
}

在这里插入图片描述


思路2–空间换时间

创建一个临时数组,大小为numsSize;
同时把nums数组中,不等于val的值,移动到临时数组temp中;
然后再把temp的值覆盖回去nums中;


时间复杂度O(n);
空间复杂度O(n);


实现代码:


int removeElement(int* nums, int numsSize, int val)
{
    int *temp = (int*)malloc(sizeof(int)*numsSize);
    int j = 0;//执行临时数组的下标
    
    //找不等于val的值放到临时数组
    for(int i = 0;i<numsSize;i++){
        if(val != nums[i]){
            temp[j++] = nums[i];
        }
    }
    //把临时数组的值,覆盖回去
    //上面的循环结束后,j  = 不是val元素的个数
    for(int i = 0;i<j;i++){
        nums[i] = temp[i];
    }
    return j;
}

在这里插入图片描述


思路3–双指针

定义两个指针:一个dst,一个src;
dst表示目的地指针,src是源指针,src用来移动寻找不等于val的值;
src找到不等于val的值那么就把它赋值给dst对应的值,即nums[dst] = nums[src],同时dst++;src++;
src碰到于val相等的值,那么src++;其他不变;


时间赋值度O(n);
空间复杂度度O(1);


实现代码:

int removeElement(int* nums, int numsSize, int val)
{
    int dst = 0; 
    int src = 0;

    while(src < numsSize){
        if(nums[src] !=val){
            nums[dst++] = nums[src++];
        }else{
            src++;
        }
    }
    //当退出循环后,dst就是元素个数
  

在这里插入图片描述


  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1. 创建顺序栈的结构、出栈、入栈、取栈顶元素算法: 顺序栈可以使用Python中的列表来实现。定义一个空列表来表示空栈,使用append()方法实现入栈操作,使用pop()方法实现出栈操作并返回被元素。使用[-1]索引来取栈顶元素。 以下是示例代码: ```python class Stack(): def __init__(self): self.items = [] def is_empty(self): return self.items == [] def push(self, item): self.items.append(item) def pop(self): return self.items.pop() def peek(self): return self.items[-1] ``` 2. 创建判断表达式括号匹配、判断运算符、运算符优先级和两数运算的函数: 可以使用栈来实现表达式求值。先将操作数压入栈中,当遇到运算符时,取出相应的操作数按照运算符计算,将结果再次压入栈中。最后栈中剩余的操作数即为最终结果。 以下是示例代码: ```python def is_operator(c): return c in ['+', '-', '*', '/'] def operator_priority(operator): return {'+': 1, '-': 1, '*': 2, '/': 2}[operator] def calculate(num1, num2, operator): if operator == '+': return num1 + num2 elif operator == '-': return num1 - num2 elif operator == '*': return num1 * num2 elif operator == '/': return num1 / num2 def evaluate_expression(expression): stack_num = [] stack_operator = [] for c in expression: if c.isdigit(): stack_num.append(int(c)) elif is_operator(c): while stack_operator and operator_priority(stack_operator[-1]) >= operator_priority(c): num2 = stack_num.pop() num1 = stack_num.pop() operator = stack_operator.pop() result = calculate(num1, num2, operator) stack_num.append(result) stack_operator.append(c) elif c == '(': stack_operator.append(c) elif c == ')': while stack_operator and stack_operator[-1] != '(': num2 = stack_num.pop() num1 = stack_num.pop() operator = stack_operator.pop() result = calculate(num1, num2, operator) stack_num.append(result) stack_operator.pop() while stack_operator: num2 = stack_num.pop() num1 = stack_num.pop() operator = stack_operator.pop() result = calculate(num1, num2, operator) stack_num.append(result) return stack_num[0] ``` 3. 实现中缀表达式求值算法: 实现中缀表达式求值算法的思路与上述样例类似。在算法中,需要将中缀表达式转为后缀表达式,在后缀表达式中进行求值。 以下是示例代码: ```python def infix_to_postfix(expression): stack_operator = [] postfix = [] for c in expression: if c.isdigit(): postfix.append(c) elif is_operator(c): while stack_operator and stack_operator[-1] != '(' and operator_priority(stack_operator[-1]) >= operator_priority(c): postfix.append(stack_operator.pop()) stack_operator.append(c) elif c == '(': stack_operator.append(c) elif c == ')': while stack_operator and stack_operator[-1] != '(': postfix.append(stack_operator.pop()) stack_operator.pop() while stack_operator: postfix.append(stack_operator.pop()) return postfix def evaluate_infix_expression(expression): postfix = infix_to_postfix(expression) stack = [] for c in postfix: if c.isdigit(): stack.append(int(c)) elif is_operator(c): num2 = stack.pop() num1 = stack.pop() result = calculate(num1, num2, c) stack.append(result) return stack[0] ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

呋喃吖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值