c语言问题,高手请进啊。。。
答案:4 悬赏:0 手机版
解决时间 2021-11-13 10:58
- 提问者网友:夢醒日落
- 2021-11-12 22:09
c语言问题,高手请进啊。。。
最佳答案
- 五星知识达人网友:千夜
- 2021-11-12 22:34
#include "stdio.h"
int main()
{
int i,j,k,m,a[3];
for(i=101;i<666;i++)
{
m=i;
j=0;
// 将十进制的自然数 i 各位上的数字分离出来
while(m>0)
{
a[j++]=m%10;
m=m/10;
}
if(a[0]==0)
{
continue;
}
if(a[0]+a[1]*7+a[2]*49 == a[2]+a[1]*9+a[0]*81)
{
printf("%d\n",a[0]+a[1]*7+a[2]*49);
}
}
return 0;
}
#include "stdio.h"
// 改变这个常量,可以找任意位数的,不仅仅是三位数
const int NUM_OF_DIGIT = 2;
int main()
{
int i,j,k,m;
int num_7base[NUM_OF_DIGIT],num_9base[NUM_OF_DIGIT];
for(i=0;;i++)
{
m=i;
j=0;
// 将十进制的自然数 i 转换成七进制
do
{
// 只保持转换结果的末 NUM_OF_DIGIT 位,多余位不保存
if(j < NUM_OF_DIGIT)
{
num_7base[j]=m%7;
}
j++;
m=m/7;
}while(m>0);
// 十进制的自然数 i 转换成七进制是少于 NUM_OF_DIGIT 位数,继续枚举下一个数字
if(j < NUM_OF_DIGIT)
{
continue;
}
// 十进制的自然数 i 转换成七进制是刚好 NUM_OF_DIGIT 位数,进行九进制转换
else if(j == NUM_OF_DIGIT)
{
m=i;
j=0;
// 将十进制的自然数 i 转换成九进制
do
{
// 只保持转换结果的末 NUM_OF_DIGIT 位,多余位不保存
if(j < NUM_OF_DIGIT)
{
num_9base[j++]=m % 9;
}
m=m/9;
}while(m>0);
// 十进制的自然数 i 转换成九进制是刚好 NUM_OF_DIGIT 位数
if(j == NUM_OF_DIGIT)
{
// 判断十进制的自然数 i 的七进制数码,和九进制数码,顺序是否正好相反
for(j = 0 ; j < NUM_OF_DIGIT ; j ++)
{
if(num_7base[j] != num_9base[NUM_OF_DIGIT - j - 1])
{
break;
}
}
if(j == NUM_OF_DIGIT)
{
// 输出该自然数的十进制
printf("%d(10) ",i);
// 输出该自然数的七进制
for(j = NUM_OF_DIGIT-1 ; j >= 0 ; j --)
{
printf("%d",num_7base[j]);
}
printf(" (7)");
// 输出该自然数的九进制
for(j = NUM_OF_DIGIT-1 ; j >= 0 ; j --)
{
printf("%d",num_9base[j]);
}
printf(" (9)\n");
}
}
}
// 十进制的自然数 i 转换成七进制是大于 NUM_OF_DIGIT 位数,不再枚举下一个数字,跳出
else if(j > NUM_OF_DIGIT)
{
break;
}
}
return 0;
}
int main()
{
int i,j,k,m,a[3];
for(i=101;i<666;i++)
{
m=i;
j=0;
// 将十进制的自然数 i 各位上的数字分离出来
while(m>0)
{
a[j++]=m%10;
m=m/10;
}
if(a[0]==0)
{
continue;
}
if(a[0]+a[1]*7+a[2]*49 == a[2]+a[1]*9+a[0]*81)
{
printf("%d\n",a[0]+a[1]*7+a[2]*49);
}
}
return 0;
}
#include "stdio.h"
// 改变这个常量,可以找任意位数的,不仅仅是三位数
const int NUM_OF_DIGIT = 2;
int main()
{
int i,j,k,m;
int num_7base[NUM_OF_DIGIT],num_9base[NUM_OF_DIGIT];
for(i=0;;i++)
{
m=i;
j=0;
// 将十进制的自然数 i 转换成七进制
do
{
// 只保持转换结果的末 NUM_OF_DIGIT 位,多余位不保存
if(j < NUM_OF_DIGIT)
{
num_7base[j]=m%7;
}
j++;
m=m/7;
}while(m>0);
// 十进制的自然数 i 转换成七进制是少于 NUM_OF_DIGIT 位数,继续枚举下一个数字
if(j < NUM_OF_DIGIT)
{
continue;
}
// 十进制的自然数 i 转换成七进制是刚好 NUM_OF_DIGIT 位数,进行九进制转换
else if(j == NUM_OF_DIGIT)
{
m=i;
j=0;
// 将十进制的自然数 i 转换成九进制
do
{
// 只保持转换结果的末 NUM_OF_DIGIT 位,多余位不保存
if(j < NUM_OF_DIGIT)
{
num_9base[j++]=m % 9;
}
m=m/9;
}while(m>0);
// 十进制的自然数 i 转换成九进制是刚好 NUM_OF_DIGIT 位数
if(j == NUM_OF_DIGIT)
{
// 判断十进制的自然数 i 的七进制数码,和九进制数码,顺序是否正好相反
for(j = 0 ; j < NUM_OF_DIGIT ; j ++)
{
if(num_7base[j] != num_9base[NUM_OF_DIGIT - j - 1])
{
break;
}
}
if(j == NUM_OF_DIGIT)
{
// 输出该自然数的十进制
printf("%d(10) ",i);
// 输出该自然数的七进制
for(j = NUM_OF_DIGIT-1 ; j >= 0 ; j --)
{
printf("%d",num_7base[j]);
}
printf(" (7)");
// 输出该自然数的九进制
for(j = NUM_OF_DIGIT-1 ; j >= 0 ; j --)
{
printf("%d",num_9base[j]);
}
printf(" (9)\n");
}
}
}
// 十进制的自然数 i 转换成七进制是大于 NUM_OF_DIGIT 位数,不再枚举下一个数字,跳出
else if(j > NUM_OF_DIGIT)
{
break;
}
}
return 0;
}
全部回答
- 1楼网友:煞尾
- 2021-11-13 00:46
条理清晰,封装合理,测试到位。
#includetypedef enum boolean{FALSE, TRUE}BOOL;
//this function is to find a natural num within 3,whoes
//7 decimal is the reverse to 9 decimal.
//function to calculate a Natural num to a decimal low euqal than 10.
//num the num that to be dealed.
//whichDecimal what type of data you want such as HEX OCT or binary.
int ExchangeDecimal(int num, int whichDecimal)
{
int tmp = 0;
int multiRate = 1;
while(num > whichDecimal)
{
tmp += (num % whichDecimal)*multiRate;
num = num / whichDecimal;
multiRate *=10;
}
tmp += num * multiRate;
return tmp;
}
//reverse num
int ReverseNum(int num)
{
int cookData = 0;
while(num > 0)
{
cookData *= 10;
cookData += (num%10);
num = num / 10;
}
return cookData;
}
//find the num and print the num
//num to be dealed ,num no big than 999 is required.
BOOL FindData(int num)
{
int sevenDecimal = 0;
int nineDecimal = 0;
int reverseNum = 0;
//first calculate the targetdecimal;
sevenDecimal = ExchangeDecimal(num, 7);
nineDecimal = ExchangeDecimal(num, 9);
//7 Decimal and 9 decimal not big than 999
if(sevenDecimal>777 || nineDecimal >999)
return FALSE;
//reverse 9decimal
reverseNum = ReverseNum(nineDecimal);
if(sevenDecimal == reverseNum)
printf("%d ",num);
else return FALSE;
}
int main(int argc, char **argv)
{
if(argc < 3)
{
printf("Usage: ./a.out num decimal ");
return;
}
int num = atoi(argv[1]);
int dec = atoi(argv[2]);
printf("The input: %d The Dec: %d",num,dec);
printf("The output: %d ",ExchangeDecimal(num,dec));
printf("The reverse %d is %d ",num,ReverseNum(num));
int i = 999;
while(i)
{
FindData(i);
i--;
}
return 0;
}
- 2楼网友:迷人又混蛋
- 2021-11-13 00:05
printf("%d\n",a[0]+a[1]*7+a[2]*49);改成printf("%d\n",i);
因为你这里的i是7进制数,是%10来取各位数的,你再a[0]+a[1]*7+a[2]*49运算就是转成10进制数了,你再仔细看看
因为你这里的i是7进制数,是%10来取各位数的,你再a[0]+a[1]*7+a[2]*49运算就是转成10进制数了,你再仔细看看
- 3楼网友:妄饮晩冬酒
- 2021-11-12 23:09
没来高手 我这个菜鸟 帮你解决吧~
数组a[]有问题啊~ a【】数组每位都是十进制啊 也就是每位都可以从0到9 可是 你下面 是把这个数组当做7进制和9进制处理的 可是当7进制的时候 a[]作为7进制的个十百位上的三个数的话 应该是0-6的范围~!与实际的范围不同 9进制的同理~
怎么说吧 思路有问题~
最好的出现的问题 体现 在 你要是把 输出换成a[0]*81+a[1]*9+a[2] 运行结果就变了~
等下试着写写 我也是暑假重拾C语言的 菜鸟一个 回答不当之处 请指正~ 写写~
我错了 你思路没问题 只是大意了~ 我修改了下 你看看 输出是 503 七进制的 也就是十进制的248
#include "stdio.h"
int main()
{
int i,a,b,c;
for(a=1;a<=7;a++)
for(b=0;b<=7;b++)
for(c=1;c<=7;c++)
{if(a*49+b*7+c==c*81+b*9+a)
printf("%d%d%d\n",a,b,c);
}
return 0;
}
数组a[]有问题啊~ a【】数组每位都是十进制啊 也就是每位都可以从0到9 可是 你下面 是把这个数组当做7进制和9进制处理的 可是当7进制的时候 a[]作为7进制的个十百位上的三个数的话 应该是0-6的范围~!与实际的范围不同 9进制的同理~
怎么说吧 思路有问题~
最好的出现的问题 体现 在 你要是把 输出换成a[0]*81+a[1]*9+a[2] 运行结果就变了~
等下试着写写 我也是暑假重拾C语言的 菜鸟一个 回答不当之处 请指正~ 写写~
我错了 你思路没问题 只是大意了~ 我修改了下 你看看 输出是 503 七进制的 也就是十进制的248
#include "stdio.h"
int main()
{
int i,a,b,c;
for(a=1;a<=7;a++)
for(b=0;b<=7;b++)
for(c=1;c<=7;c++)
{if(a*49+b*7+c==c*81+b*9+a)
printf("%d%d%d\n",a,b,c);
}
return 0;
}
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯