牛客网JZ49:把字符串转换成整数java

题目描述

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0

解题思路:首先判空,返回0.

其次,判断符号,使用标识来标记

然后:判断输入的字符串与'0'和'9'的关系,在'0'和'9'外的返回0,在'0'和'9'内的按位计算和。

最后按照标识区分,有符号的和无符号的。

import java.lang.Math;
public class Solution {
    public int StrToInt(String str) {
        if(str.length()==0){
            return 0;
        }
       // char[] b = str.toCharArray();
        int sum = 0;
        boolean flag = false;
        int sym = 0;
        if (str.charAt(0) == '+') {
            sym = 1;
        }
        if (str.charAt(0)== '-') {
            flag = true;
        }
        if (sym == 1||flag==true) {
                    for (int j = str.length() - 1; j > 0; j--) {
                        if (str.charAt(j) < '0' ||str.charAt(j)> '9') {
                            return 0;
                        }
                        sum+=(int)Math.pow(10,str.length()-j-1)*(str.charAt(j)-'0');
                }
            }else{
                    for (int j = str.length() - 1; j >= 0; j--) {
                        if (str.charAt(j) < '0' || str.charAt(j) > '9') {
                            return 0;
                        }
                        sum+=(int)Math.pow(10,str.length()-j-1)*(str.charAt(j)-'0');
                }
        }       
        return flag?sum*(-1):sum;
    }
}

这题做了很久,排一下自己遇到的坑:

1.很蠢,直接把字符串当成数组处理,就是str[i],有两种方法解决:其一是str.charAt(),其二,把字符串转成字符数组:

char[]a=str.toCharArray();

2.把数组中的值用十进制表示不会,调用Math.pow();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将十进制数转换字符串的过程需要用到除法和取模运算,这在汇编语言中可以通过使用指令实现。 下面是一个将十进制数转换字符串的汇编语言程序示例: ``` ; 将十进制数转换字符串,存储在 buf 中 ; 参数: ; edx = 十进制数 ; ecx = buf 地址 ; 返回值: ; eax = 转换字符串的长度 section .data digits db "0123456789" section .text global dec_to_str dec_to_str: push ebp mov ebp, esp push ebx push esi push edi mov ebx, ecx ; ebx = buf 地址 mov edi, ebx ; edi = 字符串指针 mov esi, edx ; esi = 十进制数 xor eax, eax ; eax = 0 cmp esi, 0 jge .loop_start ; 如果是正数则直接跳转到循环开始 mov byte [edi], '-' inc edi neg esi ; 取绝对值 inc eax .loop_start: cmp esi, 0 jz .loop_end ; 如果已经处理完了则跳转到结束 xor edx, edx div dword 10 ; edx = 余数,eax = 商 mov dl, byte [digits + eax] ; 将数字转换字符 mov byte [edi], dl ; 存储字符 inc edi inc eax ; 字符串长度加一 jmp .loop_start .loop_end: mov byte [edi], 0 ; 字符串末尾添加 NULL 结束符 sub edi, ebx ; 计算字符串长度 mov eax, edi pop edi pop esi pop ebx mov esp, ebp pop ebp ret ``` 该程序使用了除法指令 `div` 和取模指令 `mod` 来实现将十进制数转换字符串的过程。具体来说,程序将十进制数不断地除以 10,将商转换字符并存储到字符串中,直到商为 0。同时,程序还需要处理负数的情况,将负数转换绝对值后,在字符串前添加负号。最后,程序需要加上 NULL 结束符,并计算字符串的长度。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值