856. 括号的分数

38 篇文章 0 订阅
31 篇文章 0 订阅

856. 括号的分数

这道题在网上也有了很多的的解法,我的解题思路主要是利用正则表达式

解题思路:

  1. 利用正则表达式

    		regex reg("([\\(]{1})([1]?)([\\)]{1})");

     将所有()都化为1

  2. 创建新的正则表达式

    reg = "([\\(]{1})([0-9]*)([\\)]{1})";
    		regex reg1("([\\(]{1})([1]*)([\\)]{1})");
    		regex reg2("([\\(]{1})([2]*)([\\)]{1})");

    将例如(11111111)或者(22222222)这样的式子计算出来,在程序里,凡是括号内数字之和大于2的统一改变成(num+)这样的形式;

  3. 利用最后两个正则表达式

    regex reg3("[\\(]{1}[\\d]{1,}[\\+]{1}[\\)]{1}");
    regex reg4("[\\(]{1}[\\d\\+]{1,}[\\)]{1}");

    就可以处理所有的式子并得出最终的答案

 

附上测试代码:

class Solution {
public:
	int ans = 0;
	int scoreOfParentheses(string S) 
	{
		
		bool confine = 1;
		string pattern1 = "([\\(]{1})";
		string pattern2 = "([1]{1})";
		string pattern3 = "([\\)]{1})";
		regex reg("([\\(]{1})([1]?)([\\)]{1})");
		smatch m, m1;
		if (regex_search(S, m, reg))
		{
			string temp = m.str(2);
			string pre = m.prefix();
			if (temp.length()==0)
			{
				S = regex_replace(S, reg, "1");
			}
			cout << S << endl;
		}
		disum(S);
		cout << S << endl;
		reg = "([\\(]{1})([0-9]*)([\\)]{1})";
		regex reg1("([\\(]{1})([1]*)([\\)]{1})");
		regex reg2("([\\(]{1})([2]*)([\\)]{1})");
		while (regex_search(S, m, reg))
		{
			string temp = m.str();
			string pre = m.prefix();
			string suf = m.suffix();
			string num = m.str(2);
			string _te;
			auto pos = S.find(temp);
			int re = 0, te = 0, len = 0;
			if (regex_search(temp,reg1))
			{ 
				te = 2 * num.size();
				confine = 0;
			}
			else if (regex_search(temp, reg2))
			{
				te = 2 * 2 * num.size();
				confine = 0;
			}
			else
			{
				te = 2 * stoi(num);
				confine = 1;
			}
			if (confine==0)
			{
				for (int i = pre.length() - 1; i > -1; i--)
				{
					if (pre[i] > 47)
					{
						te += pre[i] - 48;
						re++;
					}
					else
						break;
				}
				for (int i = 0; i < suf.length(); i++)
				{
					if (suf[i] > 47)
					{
						te += suf[i] - 48;
						len++;
					}
					else
						break;
				}
				if (te>2)
				{
					_te = to_string(te) + '+';
				}
				else
				{
					_te = to_string(te);
				}
			}
			else
			{
				for (int i = pre.length() - 1; i > -1; i--)
				{
					if (pre[i] > 47)
					{
						te += (pre[i] - 48)*(pow(10, re));
						re++;
					}
					else
						break;
				}
				for (int i = 0; i < suf.length(); i++)
				{
					if (suf[i] > 47)
					{
						te += suf[i] - 48;
						len++;
					}
					else
						break;
				}
				_te = to_string(te) + '+';
			}

			S.replace(pos - re, temp.length() + re + len, _te);
			cout << S << endl;
		}
		regex reg3("[\\(]{1}[\\d]{1,}[\\+]{1}[\\)]{1}");
		while (regex_search(S,m,reg3))
		{
			string temp = m.str();
			string pre = m.prefix();
			string suf = m.suffix();
			string num;
			for (int i = 0; i < m.str().length(); i++)
			{
				if (m.str()[i] > 47 && m.str()[i] < 58)
				{
					num += m.str()[i];
				}
			}
			string _te;
			auto pos = S.find(temp);
			int re = 0, te = 0, len = 0;

			te = 2 * stoi(num);
			for (int i = pre.length() - 1; i > -1; i--)
			{
				if (pre[i] > 47)
				{
					te += (pre[i] - 48)*(pow(10, re));
					re++;
				}
				else
					break;
			}
			//for (int i = 0; i < suf.length(); i++)
			//{
			//	if (suf[i] > 47)
			//	{
			//		te += suf[i] - 48;
			//		len++;
			//	}
			//	else
			//		break;
			//}
			_te = to_string(te) + '+';

			S.replace(pos - re, temp.length() + re + len , _te);
			cout << S << endl;
		}
		int time = 0;
		
		regex reg4("[\\(]{1}[\\d\\+]{1,}[\\)]{1}");
		while(regex_search(S, m, reg4))
		{
			int t_num = 0;
			string temp = m.str();
			string pre = m.prefix();
			string suf = m.suffix();
			for (int i = temp.length()-1; i >-1; i--)
			{
				if (temp[i] > 47 && temp[i] < 58)
				{
					t_num += (temp[i] - 48)*(pow(10, time));
					time++;
				}
				else if (temp[i] == '+')
					time = 0;
			}
			string _te;
			auto pos = S.find(temp);
			int re = 0, te = 0, len = 0;

			te = 2 * t_num;
			time = 0;
			for (int i = pre.length() - 1; i > -1; i--)
			{
				if (pre[i] > 47)
				{
					te += (pre[i] - 48)*(pow(10, time));
					re++;
					time++;
				}
				else if (pre[i]=='+')
				{
					 time= 0;
					 re++;
				}
				else
					break;
			}
			_te = to_string(te) + '+';

			S.replace(pos - re, temp.length() + re + len, _te);
			cout << S << endl;
			time = 0;
		}


		for (int i = S.length()-1; i >-1; i--)
		{
			if (S[i] > 47 && S[i] < 58)
			{
				ans += (S[i] - 48)*(pow(10, time));
				time++;
			}
			else if (S[i] == '+')
				time = 0;
		}
		return ans;

	}
	int num(string temp)
	{
		int te = 0;
		for (int i = 0; i < temp.length(); i++)
		{
			te += temp[i] - 48;
		}
		return te;
	}
	void disum(string &s)
	{
		regex reg("[0-9]{2,}");
		smatch m;
		string ss;
		while  (regex_search(s, m, reg))
		{
			string temp = m.str();
			auto pos = s.find(temp);
			int te = num(temp);
			
			s.replace(pos, temp.length(), to_string(te));
			if (to_string(te).size() > 1)
			{
				auto save = s.find(to_string(te));
				ans += te;
				//ss += s.substr(0, pos + to_string(te).size());
				s.erase(0, pos + to_string(te).size());
			}
		}
		//s = ss + s;
	}
};

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 SAS 中,可以使用 `PROC FORMAT` 语句来解决两个百分数相减为负数时,数值带有括号的问题。具体方法如下: 1. 定义格式: 可以使用 `PROC FORMAT` 语句来定义一个自定义格式,将负数格式化为带有括号的字符串。例如,下面的代码定义了一个名为 `PCT_FMT` 的格式,将负数格式化为带有括号的字符串: ``` proc format; picture pct_fmt (round) low-high = '009.99%(') 0 - <low = '009.99%') ; run; ``` 其中,`low` 表示两个百分数相减得到的负数的最小值,可以根据实际情况进行调整。在上面的代码中,我们假设负数的最小值为 0,因此将 0 - `<low` 定义为负数部分的格式化方式,使用带有括号的字符串 `'009.99%(')` 表示。而对于非负数部分,我们使用不带括号的字符串 `'009.99%'` 表示。 2. 应用格式: 在对两个百分数进行相减时,可以使用 `PUT` 语句将结果格式化为定义的自定义格式 `PCT_FMT`,从而得到带有括号的字符串。例如,下面的代码演示了如何将两个百分数相减,并将结果格式化为带有括号的字符串: ``` data example; format percent1 percent2 result percent_fmt.; percent1 = 0.75; percent2 = 0.85; result = percent2 - percent1; percent_fmt. = put(result, pct_fmt.); run; proc print data=example; var percent1 percent2 result percent_fmt.; run; ``` 输出结果为: ``` percent1 percent2 result percent_fmt. 75.00% 85.00% 10.00% 10.00% ``` 其中,`percent_fmt.` 表示将 `result` 变量格式化为自定义格式 `pct_fmt.`,从而得到带有括号的字符串。在上面的代码中,由于两个百分数相减得到的结果为正数,因此 `percent_fmt.` 的值为 `' 10.00%'`,即不带括号的字符串。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值