力扣第七题——整数反转

给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。

如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。

假设环境不允许存储 64 位整数(有符号或无符号)。

示例 1:

输入:x = 123
输出:321
示例 2:

输入:x = -123
输出:-321
示例 3:

输入:x = 120
输出:21
示例 4:

输入:x = 0
输出:0

提示:

-231 <= x <= 231 - 1

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解法一
public int reverse_1(int x) {
        //当x为0或者x超出取值范围时直接返回0
        if (x == 0 || x > Integer.MAX_VALUE || x < Integer.MIN_VALUE) {
            return 0;
        } else {
            String strNum = Integer.toString(x);
            StringBuilder sb = new StringBuilder();
            for (int i = strNum.length() - 1; i >= 0; i--) {
                //当出现负号时,结束本次循环,不将负号存入StringBuilder,方便使用Integer.parseInt进行解析
                if (strNum.charAt(i) == '-') {
                    continue;
                }
                sb.append(strNum.charAt(i));
            }
            Integer integer = null;
            try {
                integer = Integer.parseInt(sb.toString());
            } catch (NumberFormatException e) {
                return 0;
            }
            if (x > 0) {
                return integer;
            } else {
                return -integer;
            }
        }
    }
解法二
public int reverse_2(int x) {
        //int数值的最大取值
        int max = Integer.MAX_VALUE;
        //int数值的最小取值
        int min = Integer.MIN_VALUE;
        //用long类型来判断是否溢出
        long rs = 0;
        //取模操作可以拿到最后一位数 , rs = rs * 10 + x % 10 的作用就是拿到反转之后的值
        //x /= 10 的作用是取出x中的每一位数同时控制循环的次数
        while (x != 0) {
            rs = rs * 10 + x % 10;
            System.out.print("rs == " + rs);
            x /= 10;
            System.out.println("   x == " + x);
        }
        if (rs > max || rs < min) {
            return 0;
        } else {
            return Integer.parseInt(rs + "");
        }
    }
这段代码是一个使用MQTT协议进行消息传输的示例。下面是对每个部分的解释: ```c++ char *address = "tcp://127.0.0.1:1234"; ``` 设置MQTT服务器的地址和端口。 ```c++ char *client_id = "MQTT_FX_Client2"; ``` 设置客户端的唯一标识符。 ```c++ char *topic = "PHM/Topics/WaveData/111"; ``` 设置消息的主题。 ```c++ std::string strResult; strResult = writer.write(root); ``` 将一个JSON对象(root)转换为字符串(strResult)。 ```c++ const int time_out = 10000; ``` 设置等待消息发布完成的超时时间(以毫秒为单位)。 ```c++ int rv; int QOS = 1; ``` 定义变量用于存储函数返回值和消息的服务质量等级。 ```c++ MQTTClient client; MQTTClient_connectOptions conn_opts = MQTTClient_connectOptions_initializer; MQTTClient_message publish_msg = MQTTClient_message_initializer; MQTTClient_message publish_msg1 = MQTTClient_message_initializer; MQTTClient_deliveryToken token; ``` 定义MQTT客户端、连接选项、发布消息和传递令牌。 ```c++ conn_opts.keepAliveInterval = 60; conn_opts.cleansession = 1; ``` 设置连接选项,包括心跳间隔和是否清除会话。 ```c++ MQTTClient_create(&client, address, client_id, MQTTCLIENT_PERSISTENCE_NONE, nullptr); ``` 创建MQTT客户端实例。 ```c++ if ((rv = MQTTClient_connect(client, &conn_opts)) != MQTTCLIENT_SUCCESS) { printf("MQTTClient_connect failure:%s\n", strerror(errno)); return 0; } ``` 尝试连接到MQTT服务器,如果连接失败,则打印错误信息并返回。 ```c++ publish_msg1.qos = QOS; publish_msg1.retained = 0; ``` 设置发布消息的服务质量等级和保留标志。 ```c++ while (1) { printf("enter the message you want to send\n"); publish_msg1.payload = (void*)strResult.c_str(); publish_msg1.payloadlen = strResult.size(); MQTTClient_publishMessage(client, topic, &publish_msg1, &token); rv = MQTTClient_waitForCompletion(client, token, time_out); printf("Message with delivery token %d delivered\n", rv); printf("%s\n", strResult.c_str()); sleep(3); } ``` 在一个无限循环中,用户可以输入要发送的消息,然后将其发布到指定的主题上。然后等待消息发布完成并打印相关信息,然后等待3秒再次循环。 请注意,这只是代码的一个片段,如果想要完整运行该代码,可能还需要其他的依赖项和逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值