我已经尝试过atoi()函数和strtol()函数,但是没有得到想要的输出。如何将字符串转换为数值(例如输入为一千)输出应为1000。
谢谢
#include<stdio.h>
#include<stdlib.h>
int main ()
{
int i;
char buffer [256];
printf ("Enter a number: ");
fgets (buffer, 256, stdin);
i = atoi (buffer);
printf ("The value entered is %d.",i);
return 0;
}
最佳答案
用自然语言解析数字并非易事。您可以使用字符串匹配来检测较小的数字,并且很容易通过拆分来解析“二十三”之类的数字,但是通用方法很困难。例如,“三十万”中的“一百”一词是指100,000,而不是100。
对此没有库函数,因为数字更好,更通用地表示为十进制数字。同样,这种功能只能以一种语言工作。
但是你可以自己动手。下面的代码将单词分为价值块(例如四个,二十三个)和乘数(例如一千个)。两者都是可选的。它保留一堆这样的值乘数对以跟踪“优先级”:“ 104”表示(1 * 100 + 4) * 1000
,而“ 104”表示1 * 1000 + 1 * 100 + 4
。当第一个乘法器小于以下乘数时,将首先对其求值。
该代码区分大小写,但可以在字符串文字上使用。下面的main
函数中有一个小型测试套件。
#include <stdlib.h>
#include <stdio.h>
#include <stdint.h>
#include <inttypes.h>
static const char *next(const char **p, int *len)
{
const char *t = NULL;
while (**p == ' ' || **p == '-') (*p)++;
if (**p == '\0') return NULL;
t = *p;
while (**p && **p != ' ' && **p != '-') (*p)++;
if (len) *len = *p - t;
return t;
}
static int eq(const char *q, const char *p, int len)
{
if (p == NULL) return 0;
while (len--) {
if (*p != *q) return 0;
if (*p == '\0' || *q == '\0') return 0;
p++; q++;
}
return (*q == '\0');
}
static int in(const char **q, const char *p, int len)
{
int ix = 0;
if (p == NULL) return 0;
while (*q) {
if (eq(*q, p, len)) return ix;
ix++;
q++;
}
return -1;
}
#define MAX 32
int parse_num(const char *p, int64_t *n)
{
static const char *ones[] = {
"zero", "one", "two", "three", "four", "five", "six",
"seven", "eight", "nine", "ten", "eleven", "twelve",
"thirteen", "fourteen", "fifteen", "sixteen",
"seventeen", "eighteen", "nineteen", NULL
};
static const char *tens[] = {
"-", "-", "twenty", "thirty", "forty", "fifty",
"sixty", "seventy", "eighty", "ninety", NULL
};
int64_t value[MAX];
int64_t base[MAX];
int nvalue = 0;
const char *t;
int neg = 0;
int len;
int x;
*n = 0;
t = next(&p, &len);
if (eq("minus", t, len)) {
neg = 1;
t = next(&p, &len);
}
while (t) {
int64_t num = 0;
int64_t mult = 1;
int valid = 0;
if (nvalue && eq("and", t, len)) t = next(&p, &len);
x = in(tens, t, len);
if (x >= 0) {
num += x * 10;
t = next(&p, &len);
valid = 1;
}
x = in(ones, t, len);
if (x >= 0) {
num += x;
t = next(&p, &len);
valid = 1;
}
if (valid == 0) {
long int l;
char *end;
l = strtol(t, &end, 10);
if (end == p) {
num = l;
valid = 1;
t = next(&p, &len);
}
}
if (eq("quadrillion", t, len)) mult = 1000000000000000LL;
if (eq("trillion", t, len)) mult = 1000000000000LL;
if (eq("billion", t, len)) mult = 1000000000LL;
if (eq("million", t, len)) mult = 1000000LL;
if (eq("thousand", t, len)) mult = 1000LL;
if (eq("hundred", t, len)) mult = 100LL;
if (mult > 1) {
valid = 1;
t = next(&p, &len);
}
if (valid == 0) return 0;
if (nvalue && base[nvalue - 1] == mult) return 0;
while (nvalue && base[nvalue - 1] < mult) {
nvalue--;
num += value[nvalue] * base[nvalue];
}
if (nvalue == MAX) return 0;
if (mult > 1 && num == 0) num = 1;
value[nvalue] = num;
base[nvalue] = mult;
nvalue++;
}
if (t != NULL) return 0;
if (nvalue == 0) return 0;
while (nvalue--) {
*n += value[nvalue] * base[nvalue];
}
if (neg) *n = -*n;
return 1;
}
int main()
{
const char *str[] = {
"zero",
"three",
"minus one",
"ten",
"twenty-one",
"eighty",
"eight hundred eighty-eight",
"three hundred and nineteen",
"eleven hundred",
"one hundred and twenty one",
"twenty-four thousand",
"thirty thousand one",
"two million",
"two hundred thirty thousand and eleven",
"three million two hundred and thirty thousand and eleven",
"minus eight trillion",
"fifty-five billion one million nine thousand and twelve",
"one thousand million",
"nine hundred thousand",
"nine thousand hundred",
"one hundred thousand million",
"nineteen hundred eighty-four",
"4 billion 294 million 967 thousand 296",
"two thousand thousand",
"minus",
"thirty-something",
NULL
};
const char **p = str;
while (*p) {
int64_t n;
int res;
res = parse_num(*p, &n);
if (res) {
printf("%18" PRId64, n);
} else {
printf("%18s", "---");
}
printf(" %s\n", *p);
p++;
}
return 0;
}
关于c - 输入为字符串,输出为int例如,输入为1,输出应为1,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/23466523/