力扣算法题(C++):1、2

1、两数之和等于目标值(两次不能取同一个数)

classSolution {

public:

//声明返回值类型:vector<int>以及传入参数:nums、target ;vector<int> res; 声明返回参数

vector<int> twoSum(vector<int>&nums, int target) {

for(int i=0;i<nums.size();i++) // 循环第一个数

{

for(int j=i+1;j<nums.size();j++) // 循环第二个数,i+1防止重复,效率更高

{

if(nums[i]+nums[j]==target) //判断是否符合条件

{

res.push_back(i); //向返回参数内写入返回值

res.push_back(j); //向返回参数内写入返回值

return res; //返回返回参数值

}

}

}

return res; //返回返回参数值(必须有)

}

};

2、两数相加

classSolution {

public:

ListNode*addTwoNumbers(ListNode*l1, ListNode*l2) { //定义返回参数类型以及传入参数

ListNode* head = new ListNode(0);

ListNode* tail = head;

int carry = 0; //进位部分

int reminds = 0; // 余数部分

int val1 = 0; //链表1的值

int val2 = 0; //链表2的值

int sums = 0; //链表1的值+链表2的值+进位部分

while (l1 != nullptr || l2 != nullptr || carry != 0) { //链表不为空或有进位即循环

val1 = l1 ? l1->val : 0; //取链表1的值

val2 = l2 ? l2->val : 0; //取链表2的值

sums = val1 + val2 + carry; //取链表1的值+链表2的值+进位部分

carry = sums / 10; // 进位部分

reminds = sums % 10; //余数部分

tail->next = newListNode(reminds); //给尾部赋值

tail = tail->next; //给尾部添加新的节点

if (l1 != nullptr) {

l1 = l1->next; //依次获取l1的下一个节点的值

}

if (l2 != nullptr) {

l2 = l2->next; //依次获取l2的下一个节点的值

}

}

ListNode* result = head->next; //返回真正的头节点

delete head; // 释放初始化的节点内存

return result; //返回计算结果

}

};

相关推荐
野犬寒鸦18 分钟前
从零起步学习并发编程 || 第四章:synchronized底层源码级讲解及项目实战应用案例
java·服务器·开发语言·jvm·后端·学习·面试
!停19 分钟前
数据结构二叉树——堆
java·数据结构·算法
virus59458 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
一匹电信狗8 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
鱼跃鹰飞9 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
没差c9 小时前
springboot集成flyway
java·spring boot·后端
时艰.10 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
梵刹古音10 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
编程彩机10 小时前
互联网大厂Java面试:从Java SE到大数据场景的技术深度解析
java·大数据·spring boot·面试·spark·java se·互联网大厂
笨蛋不要掉眼泪10 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain