题目链接:
力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台
题目:
给你一个整数
n
,请你每隔三位添加点(即 "." 符号)作为千位分隔符,并将结果以字符串格式返回。示例 1:
输入:n = 987 输出:"987"示例 2:
输入:n = 1234 输出:"1.234"示例 3:
输入:n = 123456789 输出:"123.456.789"示例 4:
输入:n = 0 输出:"0"提示:
0 <= n < 2^31
个人思路:
通过单循环遍历给定的数据,利用do while()将数据无论如何都先进行字符转换,避免数据为0而不进行数字与字符的转换操作;再通过标志位Iflag每三个数字进行插入‘.’ 并清零,且数据尾部获取用取模,再将数据尾部褪去(即将数据除10),进行依次数据利用S.insert(S.begin(),n%10+'0')进行数据前插处理,当全部插入时,给定的数据n==0,跳出do while();
代码:
class Solution {
public:
string thousandSeparator(int n) {
int Iflag=0;
string S;
//if(!n)return '0';可在此次额外加此句
do{
S.insert(S.begin(),n%10+'0');Iflag++;//获取个位数据转换为字符并且进行数据插入,标记++
n/=10;//将已经插入的个位数据进行腿去
if(Iflag==3&&n){S.insert(S.begin(),'.');Iflag=0;}//已插入三个数据并且n!=0(下个数仍可继续插入,因此插入千位符),标志清零(重置)
}while(n);//n==0,跳出循环源目标数据已经全部转换
return S;
}
};