CF1567D. Expression Evaluation Error(思维+贪心)

该博客讲解了如何通过贪心策略,利用最少的数字组合来构造一个十进制数,使其在转换为11进制时长度最长。算法涉及从左到右逐位分配最大可能值,同时确保结果为正数。

D. Expression Evaluation Error

在这里插入图片描述
在这里插入图片描述
题目大意:

给出一个十进制数,给出一个所需的数字个数,这几个数字之和为这个十进制数,并且使得其组成的数的11进制数最长,求出这一串数。

思路:
对于每一位,我们从左到右依次进行贪心,若想使得这个数的11进制表达最长,那么我们需要从左到右每一位都是最大值,但是我们也注意到,那么就是数每一位基本上都是 1 0 x ( 1 < = x < = n ) 10^x(1<=x<=n) 10x(1<=x<=n),而题目要求中,需要为正数,所以对于所有位上,我们首先给每一位分配上一个 1 1 1,依次对从左到右每一位进行判断,并且输出即可。

#define _CRT_SECURE_NO_WARNINGS
#include<bits/stdc++.h>
#define pi 3.1415926535
#define me(a,b,c) memset(a,b,sizeof c)
#define eps 0.00000001
//#define x first
//#define y second

using namespace std;

typedef long long ll;
const int mod = 1e9 + 7;
typedef pair<int, int> pii;

const int N = 1e6 + 10;
const int P = 131;
typedef unsigned long long ULL;

int main()
{
	int t;
	cin >> t;
	while (t--)
	{
		ll s, n;
		cin >> s >> n;
		ll t = 1;
		s -= n;
		while (n>1)
		{
			while (t * 10 - 1 <= s)t *= 10;
			s -= t;
			cout << t << ' ';
			t = 1;
			n--;
			s++;
		}
		if (s >= 0)cout << s + 1 << endl;
		else cout << 1 <<endl;
	}
}
//                            _ooOoo_
//                           o8888888o
//                           88" . "88
//                           (| -_- |)
//                           O\  =  /O
//                        ____/`---'\____
//                      .'  \|     |//  `.
//                     /  \|||  :  |||//  \
//                    /  _||||| -:- |||||-  \
//                    |   | \\  -  /// |   |
//                    | \_|  ''\---/''  |   |
//                    \  .-\__  `-`  ___/-. /
//                  ___`. .'  /--.--\  `. . __
//               ."" '<  `.___\_<|>_/___.'  >'"".
//              | | :  `- \`.;`\ _ /`;.`/ - ` : | |
//              \  \ `-.   \_ __\ /__ _/   .-` /  /
//         ======`-.____`-.___\_____/___.-`____.-'======
//                            `=---='
//        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
//
//             Buddha blesses the code with no bugs
// 1 2 3 4 5 6 7 8 9
// 0 1 3 0 4 1 7 0
试图计算零的负数幂。 - 函数: ^ 无法计算临时符号衍生变量。 - 变量: comp1.mat5.def.epsilonr22@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.epsilonryy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.chiyy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.Py@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Dy@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jdy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算表达式。 - 表达式: (((((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp...,comp...)+realdot(comp...,comp...)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(...,...)+realdot(...,...))^(-0.5))*0.5)*((-comp...)+(-comp...))))))))*epsilon0_const)*comp1.ec.Ey)*comp1.ec.d)*dvol_spatial 无法计算表达式的雅可比矩阵。 - 表达式: dvol_spatial*(comp1.ec.Jy*comp1.ec.d) 无法计算表达式的雅可比矩阵。 - 表达式: ((comp1.ec.Jx*test(comp1.Vx)+comp1.ec.Jy*test(comp1.Vy))*comp1.ec.d)*(dvol_spatial) 试图计算零的负数幂。 - 函数: ^ 无法计算临时符号衍生变量。 - 变量: comp1.mat5.def.epsilonr22@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.epsilonryy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.chiyy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.Py@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Dy@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jdy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算表达式。 - 表达式: (((((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp...,comp...)+realdot(comp...,comp...)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(...,...)+realdot(...,...))^(-0.5))*0.5)*((-comp...)+(-comp...))))))))*epsilon0_const)*comp1.ec.Ey)*comp1.ec.d)*dvol_spatial 无法计算表达式的雅可比矩阵。 - 表达式: dvol_spatial*(comp1.ec.Jy*comp1.ec.d) 无法计算表达式的雅可比矩阵。 - 表达式: ((comp1.ec.Jx*test(comp1.Vx)+comp1.ec.Jy*test(comp1.Vy))*comp1.ec.d)*(dvol_spatial) 试图计算零的负数幂。 - 函数: ^ 无法计算临时符号衍生变量。 - 变量: comp1.mat5.def.epsilonr22@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.epsilonryy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.chiyy@VDN$0t@VDN$2{conj@3} - 定义为: (1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(comp1.ec....,comp1.ec....)+realdot(comp1.ec....,comp1.ec....))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))) 无法计算临时符号衍生变量。 - 变量: comp1.ec.Py@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Dy@VDN$0t@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jdy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算临时符号衍生变量。 - 变量: comp1.ec.Jy@VDN$2{conj@3} - 定义为: (((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp1.ec.Ex,comp1.ec.Ex)+realdot(comp1.ec.Ey,comp1.ec.Ey)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(co...,co...)+realdot(co...,co...))^(-0.5))*0.5)*((-comp1.Vyt)+(-comp1.Vyt))))))))*epsilon0_const)*comp1.ec.Ey 无法计算表达式。 - 表达式: (((((1/unit_m_cf)*((1.0E-8*unit_S_cf)*(exp(((1.2E-5*unit_m_cf)*sqrt(realdot(comp...,comp...)+realdot(comp...,comp...)))/unit_V_cf)*((1/unit_V_cf)*((1.2E-5*unit_m_cf)*((((realdot(...,...)+realdot(...,...))^(-0.5))*0.5)*((-comp...)+(-comp...))))))))*epsilon0_const)*comp1.ec.Ey)*comp1.ec.d)*dvol_spatial 无法计算表达式的雅可比矩阵。 - 表达式: dvol_spatial*(comp1.ec.Jy*comp1.ec.d) 无法计算表达式的雅可比矩阵。 - 表达式: ((comp1.ec.Jx*test(comp1.Vx)+comp1.ec.Jy*test(comp1.Vy))*comp1.ec.d)*(dvol_spatial)
最新发布
06-22
### 零的负数幂导致错误的处理方法 在科学计算中,零的负数幂会导致数学上的未定义问题,因为任何负指数都意味着分母为零,这在数学上是非法操作。因此,在编写代码或设计算法时,需要特别注意这种特殊情况,并通过预检查和异常处理机制来避免此类错误的发生。 对于零的负数幂问题,可以采用以下方法进行处理: 1. 在执行幂运算之前,检查底数是否为零以及指数是否为负数。如果满足这两个条件,则抛出异常或返回特定值(如无穷大 `inf` 或 NaN)[^1]。 2. 使用条件语句对零的负数幂进行特殊处理。例如,在 Python 中可以这样实现: ```python def safe_pow(base, exponent): if base == 0 and exponent < 0: raise ValueError("Cannot compute negative power of zero.") return base ** exponent ``` 此外,针对表达式中可能出现的临时符号衍生变量(如 `epsilonr22`、`epsilonryy` 等),可以通过正则表达式解析变量名并确保其值有效。例如,使用正则表达式匹配负浮点数以正确识别负数[^3]。 ### 解决无法计算临时符号衍生变量的问题 当遇到无法计算的临时符号衍生变量时,通常是因为这些变量未被正确初始化或解析。解决此问题的方法包括: 1. 确保所有变量在使用前已被正确初始化。可以通过静态代码分析工具检测未初始化的变量。 2. 在解析表达式时,考虑负数的特殊情况,避免将负号误认为减法操作符。例如,在中缀表达式转后缀表达式的过程中,需要明确区分负号作为操作符还是负数的一部分[^4]。 3. 引入符号表(Symbol Table)来跟踪变量及其值。符号表可以在解析过程中动态更新,确保每个变量在使用前都有有效的值。 ### 示例代码 以下是一个示例代码,展示如何安全地计算幂运算并处理负数: ```python import re def is_negative_float(value): # 使用正则表达式判断是否为负浮点数 pattern = r'^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$' return re.match(pattern, value) is not None def safe_expression_eval(expression): # 替换表达式中的负数,确保正确解析 tokens = re.findall(r'-?\d+\.?\d*|[a-zA-Z_]\w*|\S', expression) symbol_table = {} for token in tokens: if re.match(r'[a-zA-Z_]\w*', token): # 如果是变量 if token not in symbol_table: raise ValueError(f"Undefined variable: {token}") elif is_negative_float(token): # 如果是负浮点数 continue else: try: result = eval(expression, {"__builtins__": None}, symbol_table) return result except ZeroDivisionError: raise ValueError("Division by zero encountered.") except Exception as e: raise ValueError(f"Error during evaluation: {e}") # 示例调用 expression = "epsilonr22 = -6 ** -2" symbol_table = {"epsilonr22": 0} safe_expression_eval(expression) ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值