Divide Two Integers

题目:Divide two integers without using multiplication, division and mod operator.


思路:注意越界问题。

比如:

 -2147483648/1=-2147483648
 -2147483648/-1=2147483647

最主要的应该是如何进行除法吧,思路如下:a/b,a-b --  a-2*b -- a-2*2*b,不断的迭代,设置一个while循环。

一开始b赋值给c,在接下来的循环里for(int i=0;a>=c;i++,c<<1)

A每次减去c,c每次自己乘以2,代表了每次里面都有2个c,

尽管c每次乘以2,但是对于所以result每次都是需要进行(1<<i),代表第i次多少个c,a<c结束。

下次继续循环


代码:

typedef long long ll;
class Solution {
public:
//https://leetcode.com/problems/divide-two-integers/
    int divide(int dividend, int divisor) {
        ll a = dividend >= 0 ? dividend : -(ll)dividend;
        ll b = divisor >= 0 ? divisor : -(ll)divisor;
        ll result = 0, c = 0;
        bool sign = (dividend > 0 && divisor < 0) || (dividend < 0 && divisor > 0);

        while(a>=b){
            c=b;
            for(int i=0;a>=c;i++,c<<=1){//c<<suoy=1,每一次这个操作就会使得除数*2。因为他是迭代的,
                                        //所以循环内部是+(1<<i)-->代表多少个倍数的除数。
                a=a-c;
                result=result+(1<<i);
            }
        }
        if (sign) {
            return max((ll)INT_MIN, -result);
        } else {
            return min((ll)INT_MAX, result);
        }
    }
};


【SCI复现】含可再生能源与储能的区域微电网最优运行:应对不确定性的解鲁棒性与非预见性研究(Matlab代码实现)内容概要:本文围绕含可再生能源与储能的区域微电网最优运行展开研究,重点探讨应对不确定性的解鲁棒性与非预见性策略,通过Matlab代码实现SCI论文复现。研究涵盖多阶段鲁棒调度模型、机会约束规划、需求响应机制及储能系统优化配置,结合风电、光伏等可再生能源出力的不确定性建模,提出兼顾系统经济性与鲁棒性的优化运行方案。文中详细展示了模型构建、算法设计(如C&CG算法、大M法)及仿真验证全过程,适用于微电网能量管理、电力系统优化调度等领域的科研与工程实践。; 适合人群:具备一定电力系统、优化理论和Matlab编程基础的研究生、科研人员及从事微电网、能源管理相关工作的工程技术人员。; 使用场景及目标:①复现SCI级微电网鲁棒优化研究成果,掌握应对风光负荷不确定性的建模与求解方法;②深入理解两阶段鲁棒优化、分布鲁棒优化、机会约束规划等先进优化方法在能源系统中的实际应用;③为撰写高水平学术论文或开展相关课题研究提供代码参考和技术支持。; 阅读建议:建议读者结合文档提供的Matlab代码逐模块学习,重点关注不确定性建模、鲁棒优化模型构建与求解流程,并尝试在不同场景下调试与扩展代码,以深化对微电网优化运行机制的理解。
下面是一个Java程序,名为ArithmeticT1,可以接受三个命令行参数:两个整数和一个算术运算符(+,-,*,/)。程序将对这两个整数执行相应的操作,并显示结果。请注意,您需要使用异常处理程序(try-catch语句)来处理非数字输入作为操作数(两个整数中的一个) - 如果任何操作数是非数字,则程序将终止,并在退出前显示带有错误操作数输入的消息。此外,程序还应处理运算符的错误输入。 ``` public class ArithmeticT1 { public static void main(String[] args) { if(args.length != 3) { System.out.println("Usage: java ArithmeticT1 operand1 operator operand2"); System.exit(1); } int operand1 = 0; int operand2 = 0; int result = 0; try { operand1 = Integer.parseInt(args[0]); operand2 = Integer.parseInt(args[2]); } catch (NumberFormatException ex) { System.out.println("Wrong operand input"); System.exit(1); } switch (args[1]) { case "+": result = operand1 + operand2; break; case "-": result = operand1 - operand2; break; case "*": result = operand1 * operand2; break; case "/": if (operand2 == 0) { System.out.println("Cannot divide by zero"); System.exit(1); } result = operand1 / operand2; break; default: System.out.println("Wrong operator input"); System.exit(1); } System.out.println(operand1 + " " + args[1] + " " + operand2 + " = " + result); } } ``` 这个程序首先检查是否有三个命令行参数。如果不是,则显示用法消息并退出程序。程序然后尝试将第一个和第三个参数解析为整数。如果任何一个参数不是整数,则显示错误消息并退出程序。如果两个参数都是整数,则根据第二个参数执行相应的算术运算。如果第二个参数是除法运算符,程序还会检查第二个操作数是否为零。如果是,则显示错误消息并退出程序。最后,程序将显示算术表达式和结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值