数字与字符串互转

目标

  • 将字符串转为数字
  • 将数字转为字符串

将十进制字符串转为数字

可选符号 ‘-’、‘+’。

例:toInteger(“-1234”) 返回 -1234。

想法:

定义一个变量 sign 存储符号位,0 代表正,1 代表负。

得到每个字符减去 ‘0’,得到实际数值 d,例 ‘8’ - ‘0’ = 8。

再使用公式根据每位上的数算出总值 n = 10 * n + d。

1234 = 1 * 103 + 2 * 102 + 3 * 101 + 4

= 10 * (1 * 102 + 2 * 101 + 3) + 4

= 10 * (10 * (10 * 1 + 2) + 3) + 4

int n = 0;
n = 10 * n + 1;
n = 10 * n + 2;
n = 10 * n + 3;
n = 10 * n + 4;
int toInteger(char s[]) {
    int sign = 0;
    int i = 0;
    switch (s[0]) {
        case '-':
            sign = 1;
            i = 1;
            break;    
        case '+':
            i = 1;
            break;
    }
	int n = 0;
    while (s[i] >= '0' && s[i] <= '9') {
        n = 10 * n + s[i] - '0';
        i++;
    }
    return sign == 0 ? n : -n;
}

将数字转为字符串

例:itoa(-1234) 返回 “-1234”,但考虑到 c 语言的字符串并不像 Java 那么好用,可以拼接,我确定不了字符数组的长度,越界了也不会报错,所以具体长度用调用者决定。

我的思路:

sign 存储符号,0 代表正,1 代表负,需要添加 ‘-’。

获取各位数上的值。

个位:i % 10。

十位:i / 10 % 10。

百位:i / 100 % 10。

例:获取 1234 的各位值。

个位:1234 % 10 = 4
十位:1234 / 10 = 123,123 % 10 = 3
百位:1234 / 100 = 12,12 % 10 = 2
千位:1234 / 1000 = 1,1 % 10 = 1
万位:1234 / 10000 = 0

循环就以 /= 10 不为 0 作为条件。

void itoa(int n, char s[]) {
	int sign = 0;
	if (n < 0) {
		sign = 1;
		n = -n;
	}
   
    int i = 0;
    do {
        s[i++] = n % 10 + '0';
    } while ((n /= 10) != 0);
    if (sign == 1) {
        s[i++] = '-';
    }
	s[i] = '\0';
    // 4321-
    reverse(s);
}
void reverse(char s[]) {
    int leng = length(s);
    for (int i = 0; i < (leng - 1) / 2; i++) {
        swap(s, i, leng-2-i);
    }
}

int length(char s[]) {
    int i = 0;
    while (s[i++] != '\0') {}
    return i;
}

void swap(char s[], int i, int j) {
    char c = s[j];
    s[j] = s[i];
    s[i] = c;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值