【模拟】P1067 多项式输出

https://www.luogu.com.cn/problem/P1067

考点:模拟、字符串

这是一道水题,水题能卡人往往是有某些数据没考虑到。

在这里插入图片描述
在这里插入图片描述
题意:输入系数,输出多项式。

解法:

需要把所有特殊情况考虑到,分别是:
-1x 输出为 -x
+1x 输出为 x
第一项的系数为+,不能输出+号
系数为0不输出
x^0仅输出系数
x^1输出为x

我的做法是先不考虑这些特殊情况,把系数和指数全部存到字符串,再把特殊情况删除或替换。这题我没过是因为 x^1 这种情况我直接替换成x了,而没有考虑到 x^19 这种情况,为了解决这个问题我给每一项的结尾加了一个#字符,然后将x^1#替换为x#,这样就可以了。最后把所有#删掉即可。

代码中用到了字符串流stringstream,因为我需要把正整数的正号保留,所以要用到 std::showpos 这个东西。

#include <bits/stdc++.h>
using namespace std;
int main() {
	int n;
	while (cin >> n) {
		string s;
		stringstream ss;
		for (int i = n; i >= 0; i--) {
			int x; cin >> x;
			if (x == 0) continue; // 系数是0的项不需要
			ss << showpos << x << noshowpos << "x^" << i << "#";
		}
		ss >> s;
		//cout << s << endl;
		// x^0删除
		if (s.find("x^0") != s.npos) {
			s.replace(s.find("x^0"), 3, "");
		}
		//cout << s << endl;

		// x^1替换为x  BUG!! 比如 x^19 变成 x9
		if (s.find("x^1#") != s.npos) {
			s.replace(s.find("x^1#"), 4, "x#");
		}
		//cout << s << endl;

		// -1x +1x 替换为 -x +x
		while (s.find("-1x") != s.npos) {
			s.replace(s.find("-1x"), 3, "-x");
		}
		while (s.find("+1x") != s.npos) {
			s.replace(s.find("+1x"), 3, "+x");
		}
		//cout << s << endl;

		// 开头的正号不需要
		if (s[0] == '+') s = s.erase(0, 1); 
		//cout << s << endl;

		// 结尾的符号不需要
		if (s.size() != 0 && ispunct(s[s.size()-1])) s = s.erase(s.size() - 1);

		//cout << s << endl << endl;

		while (s.find("#") != s.npos) s = s.erase(s.find("#"), 1);

		cout << s << endl;
	}
	return 0;
}

这种水题虽然没有难度,但是如果漏算了某些特殊情况,那也只能认倒霉了。
这题我的测试用例全部都是指数在10以内的,当然就试不出 x^19 这种BUG了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值