求大神帮忙看一下这段C语言代码哪有问题,自己做的一道编程题题目是这样的:古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直
来源:学生作业帮助网 编辑:六六作业网 时间:2024/11/27 16:20:12
求大神帮忙看一下这段C语言代码哪有问题,自己做的一道编程题题目是这样的:古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直
求大神帮忙看一下这段C语言代码哪有问题,自己做的一道编程题
题目是这样的:
古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直不能忍受,所以在现代很少使用了.之所以这样,不是因为发明表示法的人的智力的问题,而是因为一个宗教的原因,当时的宗教禁止在数字中出现0的概念!
罗马数字的表示主要依赖以下几个基本符号:
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
这里,我们只介绍一下1000以内的数字的表示法.
单个符号重复多少次,就表示多少倍.最多重复3次.比如:CCC表示300 XX表示20,但150并不用LLL表示,这个规则仅适用于I X C M.
本题目的要求是:请编写程序,由用户输入若干个罗马数字串,程序输出对应的十进制表示.
输入格式是:第一行是整数n,表示接下来有n个罗马数字(n<100).以后每行一个罗马数字.罗马数字大小不超过999.
要求程序输出n行,就是罗马数字对应的十进制数据.
例如,用户输入:
3
LXXX
XCIII
DCCII
则程序应该输出:
80
93
702
我自己先按照实现一个转换编的,算法没有任何问题,但是改成:第一行是整数n,表示接下来有n个罗马数字,要求程序输出n行这种形式就出问题了,我用VS2010编译调试后输完第一个数回车就这样了
以下是我的代码,求大神帮忙看看这段代码哪里有问题,应该是指针有问题,但我看不出来啊.应该怎么改,大体不用动,函数里的算法不用看懂也不影响,可能有点长,在此先谢谢了!
#include<stdio.h>
#include<stdlib.h>
void turn(char *a);
main()
{
int i,n;
char *d[100];
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s",d[i]);
for(i=0;i<n;i++)
turn(d[i]);
return 0;
}
void turn(char *a)
{
int b[20]={0},i,j,*p,sum;
for(i=0;*(a+i)!='\0';i++)
{
switch(a[i]){
case 'I':b[i]=1;break;
case 'V':b[i]=5;break;
case 'X':b[i]=10;break;
case 'L':b[i]=50;break;
case 'C':b[i]=100;break;
case 'D':b[i]=500;break;
case 'M':b[i]=1000;break;
default:{
printf("Error\n");
exit(1);
}
}
}
sum=0;
p=b;
for(j=0;j<20;j++)
{
if(*p>=*(p+1))
sum+=*p;
else
sum-=*p;
p++;
}
printf("%d\n",sum);
}
求大神帮忙看一下这段C语言代码哪有问题,自己做的一道编程题题目是这样的:古罗马帝国开创了辉煌的人类文明,但他们的数字表示法的确有些繁琐,尤其在表示大数的时候,现在看起来简直
原因:
char *d[100];
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%s",d[i]);
没有给d这个数组中的各元素分配存储空间(也即d[0]到d[99]这100个指针变量指向不明确),又强行给这个元素指向的地址写入值
所以,程序崩溃
char *d[100];
改成
char d[100][100];即可
运行结果: