Excel Sheet Column Title 把整数转换为大写字母的组合

Given a positive integer, return its corresponding column title as appear in an Excel sheet.

For example:

    1 -> A
    2 -> B
    3 -> C
    ...
    26 -> Z
    27 -> AA
    28 -> AB 

/*String s="ABC"; 
System.out.println(s.charAt(2)-'A');//char可以自动转换为Int类型。再进行运算 
System.out.println('A');*/
单引号引的数据 是char类型的
双引号引的数据 是String类型的
转java中String和int以及char相加的时候系统自动调用的int和char的包装类的toString方法,将int型和char型转换成了String型,还要注意的一点是,String类型(说对象更好)都是不可变的

String 类型和StringBuffer的主要性能区别:String是不可变的对象, 因此在每次对String 类型进行改变的时候,都会生成一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,性能就会降低。

使用 StringBuffer 类时,每次都会对 StringBuffer 对象本身进行操作,而不是生成新的对象并改变对象引用。所以多数情况下推荐使用 StringBuffer ,特别是字符串对象经常改变的情况下。

基本原则:如果要操作少量的数据,用String ;单线程操作大量数据,用StringBuilder ;多线程操作大量数据,用StringBuffer。

public class Solution {
    public String convertToTitle(int n) {
        String s=new String();
        String res=new String();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');//把asicc码转化为字符,其他的理解只是数学上的理解了
            s+=c; //你看,是可以直接加上c的哦
            n=(n%26==0)?(n/26-1):(n/26);
        } //求出来的字符串跟题目要求恰好是相反的
        for(int i=s.length()-1;i>=0;i--){ //这个for语句实现字符串的反转
            c=(char)s.charAt(i);
            res+=c;
        }
        return res;
    }
}

 
下边的写法是用了StringBuilder进行反转,因为StringBuilder自带反转方法
public class Solution {
    public String convertToTitle(int n) {
        StringBuilder s=new StringBuilder();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');
            s.append(c); //它不能用+,只能用append方法
            n=(n%26==0)?(n/26-1):(n/26);
        }
        return s.reverse().toString();
    }
}


StringBuffer也是可以的
public class Solution {
    public String convertToTitle(int n) {
        StringBuffer s=new StringBuffer();
        char c;
        while(n!=0){
            c=(char)((n-1)%26+'A');
            s.append(c);
            n=(n%26==0)?(n/26-1):(n/26);
        }
        return s.reverse().toString(); //使用StringBuffer,如果想转成String类型,可以调用StringBuffer的toString()方法。
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值