最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

CCI2.5链表整数求和

来源:动视网 责编:小采 时间:2020-11-09 15:29:37
文档

CCI2.5链表整数求和

CCI2.5链表整数求和:给定两个用链表表示的整数,每一个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。 示例 输入:(7-1-6) (5-9-2), 即 617 295. 输出:2-1-9, 即912. 进阶 假设这些数位是正向存放的,
推荐度:
导读CCI2.5链表整数求和:给定两个用链表表示的整数,每一个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。 示例 输入:(7-1-6) (5-9-2), 即 617 295. 输出:2-1-9, 即912. 进阶 假设这些数位是正向存放的,


给定两个用链表表示的整数,每一个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。 示例 输入:(7-1-6) (5-9-2), 即 617 295. 输出:2-1-9, 即912. 进阶 假设这些数位是正向存放的,请

给定两个用链表表示的整数,每一个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。

示例

输入:(7->1->6) + (5->9->2), 即 617 + 295.

输出:2->1->9, 即912.

进阶

假设这些数位是正向存放的,请再做一遍。

示例

输入:(6->1->7) + (2->9->5), 即617 + 295.

输出:9->1->2, 即912.

**进阶的解法告诉我们,涉及单链表逆序的问题,可以借助栈来解决。

package test;

import java.util.Stack;

public class AddLinkedInt {
	
	//两个整数反向存放
	//即,个位排在链表的首部
	public Node addLinkedInt(Node l1, Node l2){
	
	Node newHead = new Node(0);
	Node tail = newHead;
	int carry = 0;
	Node p1 = l1, p2 = l2;
	while(p1!=null || p2!=null){
	int val1 = (p1==null)? 0 : p1.val;
	int val2 = (p2==null)? 0 : p2.val;
	int val = (val1+val2+carry)%10;
	carry = (val1+val2+carry)/10;
	tail.next = new Node(val);
	tail = tail.next;
	}
	if(carry != 0)
	tail.next = new Node(carry);
	return newHead.next;
	}
	
	//两个整数正向存放
	//即,个位排在链表的末尾
	public Node addLinkedInt(Node l1, Node l2){
	//这里要借助栈来处理
	Stack st1 = new Stack();
	Stack st2 = new Stack();
	Node p1=l1, p2=l2;
	//将两链表的数据分别压入栈中
	while(p1 != null){
	st1.push(p1.val);
	p1 = p1.next;
	}
	while(p2 != null){
	st2.push(p2.val);
	p2 = p2.next;
	}
	//将结果相加入栈
	Stack res = new Stack();
	int carry=0;
	while( !st1.empty() || !st2.empty()){
	int val1 = st1.empty() ? 0 : st1.pop();
	int val2 = st2.empty() ? 0 : st2.pop();
	res.push((val1+val2+carry)%10);
	carry = (val1+val2+carry)/10;
	}
	if(carry != 0)//注意进位的处理
	res.push(carry);
	Node newHead = new Node(0);
	Node tail = newHead;
	while(!res.empty()){
	tail.next = new Node(res.pop());
	tail = tail.next;
	}
	return newHead.next;	
	}
}

文档

CCI2.5链表整数求和

CCI2.5链表整数求和:给定两个用链表表示的整数,每一个节点包含一个数位。这些数位是反向存放的,也就是个位排在链表首部。编写函数对这两个整数求和,并用链表形式返回结果。 示例 输入:(7-1-6) (5-9-2), 即 617 295. 输出:2-1-9, 即912. 进阶 假设这些数位是正向存放的,
推荐度:
标签: 两个 求和 表示
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top