数据结构与算法MOOC-第二章线性表(多项式加法(map) 字符串插入 位查询 放苹果(递归orDP)大整数乘法)

本文是关于数据结构与算法Mooc的第二章线性表的学习笔记,涵盖了多项式加法、字符串插入、位查询、放苹果问题(递归与DP解法)以及大整数乘法。在多项式加法中使用了map容器进行系数合并,字符串插入通过查找最大ASCII码值进行插入,位查询涉及位运算的应用,放苹果问题通过递归和动态规划求解,大整数乘法则通过模拟算术乘法实现。
摘要由CSDN通过智能技术生成
  • 数据结构与算法Mooc-第二章线性表


  • 1、多项式加法

题目链接:1:多项式加法

思路:①看到需要合并同系数,排序果断选择用map容器,次数相同合并,那么Key值(First)肯定是选择次数

           ②输入是系数为负停止,那么第一次输入系数为负只需要continue,第二次结束输入(break)

           ③输入合法值时查找,如果找到对应次数,系数相加,找不到就插入该元素

代码:

#include<iostream>	
#include<map>
using namespace std;


int main()
{
	int Number, Pow;
	int Test_Time;
	cin >> Test_Time;
	while (Test_Time--)
	{
		map<int, int> Polynomial;   //first-pow,second-Number
		int Break_Flag = 0;
		while (cin >> Number >> Pow)
		{
			if (Pow < 0)
			{
				Break_Flag++;
				if (Break_Flag== 1)  //到一表示第一组多项式输入完成
					continue;
				break;    //到2 两组都输入,结束输入
			}
			if (Polynomial.count(Pow)!=-1)     //find it
			{
				Polynomial[Pow] += Number;		//找到对应的次数,系数相加
				if (Polynomial[Pow]==0)		//系数为0
					Polynomial.erase(Pow);		//删除该子项
			}
			else
				Polynomial.insert(make_pair(Pow, Number));  //没有对应次数,加入该子项
		}

		if (Break_Flag == 2)
		{
			auto it = Polynomial.rbegin();
			for (it; it != Polynomial.rend(); it++)   //map默认升序,所以逆序输出
			{
				if (it == Polynomial.rbegin())
					cout << "[ " << it->second << " " << it->first << " ]";
				else
					cout << " [ " << it->second << " " << it->first << " ]";
			}
			cout << endl;
		}
	}
	return 0;
}

         收获:一个新的类型:auto,迭代器类,以后不用写长长的~<...>::iterator

         待解答:我自己写的系数相加,查找,插新一直WA,求解答,错误代码放下

while (Test_Time--)
{
	map<int, int, CMP> Polynomial;   //first-pow,second-Number
	int Break_Flag = 0;
	while (cin >> Number >> Pow)
	{
		if (Pow < 0)
		{
			Break_Flag++;
			if (Break_Flag == 1)
				continue;
			break;
		}
		it = Polynomial.find(Pow);
		if (it != Polynomial.end())     //find it
		{
			it->second += Number;
			if (it->second == 0)
				Polynomial.erase(it->first);
		}
		else
			P
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值