力扣算法题(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; //返回计算结果

}

};

相关推荐
寻星探路11 小时前
【深度长文】万字攻克网络原理:从 HTTP 报文解构到 HTTPS 终极加密逻辑
java·开发语言·网络·python·http·ai·https
你撅嘴真丑14 小时前
第九章-数字三角形
算法
曹牧14 小时前
Spring Boot:如何测试Java Controller中的POST请求?
java·开发语言
uesowys14 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder14 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮14 小时前
AI 视觉连载1:像素
算法
爬山算法14 小时前
Hibernate(90)如何在故障注入测试中使用Hibernate?
java·后端·hibernate
智驱力人工智能14 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
kfyty72515 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎15 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven