java代码-望大神帮分析下,最好是把该代码的思路给分析讲解下,虽没有分但万分感谢!

问题描述

望大神帮分析下,最好是把该代码的思路给分析讲解下,虽没有分但万分感谢!

import java.math.BigDecimal;

public class NumToRMB
{

public static void main(String[] args)
{
    System.out.println(changeToBig(Double.parseDouble(args[0])));
}

public static String changeToBig(double value)
{
    char[] hunit = {'拾', '佰', '仟' }; // 段内位置表示
    char[] vunit = {'万', '亿' }; // 段名表示
    char[] digit = {'零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示
    // long midVal = (long)(value*100); ////存在精度问题,如0.9->0.8999
    BigDecimal midVal = new BigDecimal(Math.round(value * 100)); // 转化成整形,替换上句
    String valStr = String.valueOf(midVal); // 转化成字符串
    String head = valStr.substring(0, valStr.length() - 2); // 取整数部分
    String rail = valStr.substring(valStr.length() - 2); // 取小数部分

    String prefix = ""; // 整数部分转化的结果
    String suffix = ""; // 小数部分转化的结果
    // 处理小数点后面的数
    if (rail.equals("00"))
    { // 如果小数部分为0
        suffix = "整";
    }
    else
    {
        suffix = digit[rail.charAt(0) - '0'] + "角"
                + digit[rail.charAt(1) - '0'] + "分"; // 否则把角分转化出来
    }
    // 处理小数点前面的数
    char[] chDig = head.toCharArray(); // 把整数部分转化成字符数组
    boolean preZero = false; // 标志当前位的上一位是否为有效0位(如万位的0对千位无效)
    byte zeroSerNum = 0; // 连续出现0的次数
    for (int i = 0; i < chDig.length; i++)
    { // 循环处理每个数字
        int idx = (chDig.length - i - 1) % 4; // 取段内位置
        System.out.print("idx:" + idx + ".." + (chDig.length - i - 1));
        int vidx = (chDig.length - i - 1) / 4; // 取段位置
        System.out.println("**vidx" + ".." + (chDig.length - i - 1)/4);
        if (chDig[i] == '0')
        { // 如果当前字符是0
            preZero = true;
            zeroSerNum++; // 连续0次数递增
            if (idx == 0 && vidx > 0 && zeroSerNum < 4)
            {
                prefix += vunit[vidx - 1];
                preZero = false; // 不管上一位是否为0,置为无效0位
            }
        }
        else
        {
            zeroSerNum = 0; // 连续0次数清零
            if (preZero)
            { // 上一位为有效0位
                prefix += digit[0]; // 只有在这地方用到'零'
                preZero = false;
            }
            prefix += digit[chDig[i]-'0']; // 转化该数字表示
            System.out.println(chDig[i]-'0');
            if (idx > 0)
                prefix += hunit[idx - 1];
            if (idx == 0 && vidx > 0)
            {
                prefix += vunit[vidx - 1]; // 段结束位置应该加上段名如万,亿
            }
        }
    }

    if (prefix.length() > 0)
        prefix += '圆'; // 如果整数部分存在,则有圆的字样
    return prefix + suffix; // 返回正确表示
}

}

解决方案

写的挺好,注释也很清楚啊,我是不是可以理解你这块儿不太懂呢

         int idx = (chDig.length - i - 1) % 4; // 数字处于哪位,然后映射到char[] hunit = { '拾', '佰', '仟' };的下标
        System.out.println("段位置-index:" + idx + ".." + (chDig.length - i - 1));
        int vidx = (chDig.length - i - 1) / 4; //同上,找到对应char[] vunit = { '万', '亿' };的下标
        System.out.println("段名-index" + ".." + (chDig.length - i - 1) / 4);

我改了一下注释,建议断点单步调试一遍,你就懂了

时间: 2024-10-03 04:47:59

java代码-望大神帮分析下,最好是把该代码的思路给分析讲解下,虽没有分但万分感谢!的相关文章

ava基础 代码错误-Java新手,求大神帮小弟看看这段代码哪里错了,多谢!!!

问题描述 Java新手,求大神帮小弟看看这段代码哪里错了,多谢!!! class Student { //姓名 private String name; //年龄 private int age; //构造方法 public Student(){ } public Student(String name, int age){ this.name = name; this.age = age; } public String getName(){ return name; } public voi

java小白求大神帮看一下为什么会发生数组越界。代码如下:

问题描述 java小白求大神帮看一下为什么会发生数组越界.代码如下: package arraytest; public class ArrayTestSort { public static void main(String[] args) { int i,j=0; int[] arr = new int[]{100,40,60,87,34,11,56,0}; int temp = 0; for(i = 0;i<arr.length;i++){ for(j = 0;j<arr.length-

编程语言-我要用C++实现这段代码 求大神帮解释下R语言代码的意思

问题描述 我要用C++实现这段代码 求大神帮解释下R语言代码的意思 OrgData=read.csv("DownlinkPower_train.csv",header=T) TestData=read.csv("DownlinkPower_test.csv",header=T) #remove abnormal data, optional //移除异常数据 OrgData = subset(OrgData, OrgData[,1] > 0) TestData

android http POST请求方式向服务其发送数据不成功 贴出代码求大神帮解决一下

问题描述 android http POST请求方式向服务其发送数据不成功 贴出代码求大神帮解决一下 new Thread(new Runnable() { @Override public void run() { String szSrc = ""abcdefghijkl123456789123"" ; byte[] encoded = ThreeDes.encryptMode(keyBytes szSrc.getBytes()); try { /* Strin

java web-求求大神帮我解决下 。。。。。一天了还没解决 非常感谢

问题描述 求求大神帮我解决下 .....一天了还没解决 非常感谢 package edu.jju.example; import java.sql.Connection; import java.sql.DatabaseMetaData; import java.sql.SQLException; import javax.activation.DataSource; import org.apache.commons.dbcp.BasicDataSource; /** * @author Ad

java代码-请大神帮我看看这个java程序怎么运行不了,帮我调一调这个程序,谢谢

问题描述 请大神帮我看看这个java程序怎么运行不了,帮我调一调这个程序,谢谢 是这个错误Exception in thread "main" java.lang.Error: Unresolved compilation problem: import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayList; pub

代码-各位大神帮帮忙,为何我的xml网站打不开

问题描述 各位大神帮帮忙,为何我的xml网站打不开 请各位大神帮忙,为何我用火狐浏览器打开下面的xml文档就是这样 用IE是这样,到底要怎样才能完好显示!!代码都在下面,麻烦各位帮帮看看QAQ <?xml version="1.0" ?> <lectures> <lecture number="0"> <title>HTTP</title> <dates>Monday,30 August 201

一个关于数组溢出的问题,请大神帮小弟解惑

问题描述 一个关于数组溢出的问题,请大神帮小弟解惑 vc6.0环境,代码很简单,但是不管你输入的数组n是多大,a[n]的值都是n,按理说不是最大就到n-1了吗,为什么不报错? #include using namespace std; int main() {int i;int a[11]; int*p=a; for(i=0;i<=10;i++) a[i]=i; cout<<a[11]; return 0; } 解决方案 你试试int *a = new int[11];数组实际上放在栈内

c++-关于clang语法树AST操作。求大神帮帮忙。

问题描述 关于clang语法树AST操作.求大神帮帮忙. 我需要将c++代码利用clang生成语法树,在语法树上进行改动,再变回代码. 请问应该怎么做? clang生成的语法树信息存在哪里,怎么提取?怎么将AST再转成c++代码?