| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1755 人关注过本帖
标题:[求助][求助]急用!谢谢!
只看楼主 加入收藏
青春小小雪
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2007-9-16
收藏
得分:0 
恩!麻烦你了,我要下了,我现在在上课的,呵呵!抽空上来发了下帖。
2007-09-17 10:35
josen0205
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:307
专家分:52
注 册:2007-5-8
收藏
得分:0 

C语言提供系统函数char *itoa(int ,char *,int)来实现进制转换,第一个参数是要转换的十进制数,第二个参数是存放结果的字符串,第三个参数是要转换的进制数,这里本人写一个进制转换函数i_itoa各参数和系统函数一样,当然也可以直接用系统函数,这里只是想让你知道系统函数是怎么实现的.
程序只要先把输入的任意进制数转化为一个十进制数,然后就可以再把这个十进制数转换成想要的进制数就可以了

#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<string.h>
#include<math.h>

char *i_itoa(int n,char *str,int m)//将十进制数n转换得到m进制数
{
int i=0,len;
char str1[32];
memset(str1,0,sizeof(str1));
while(n)
{
if(n%m>=10)
str1[i]=n%m%10+'a';
else
str1[i]=n%m+'0';
n=n/m;
i++;
}
len=i;
for(i=0;i<len;i++)
str[i]=str1[len-1-i];
return str;
}

int i_chg(char *str,int m)//m进制数转换得到十进制数
{
int i,tmp=0,num;
int len;
len=(int)strlen(str);
for(i=0;i<len;i++)
{
if(str[i]>='a'&&str[i]<='f')
num=10+str[i]-'a';
else
num=str[i]-'0';
tmp+=num*(int)pow(m,len-1-i);
}
return tmp;
}

int main()
{
int m,n;
char str[32];
char str1[32];
memset(str,0,sizeof(str));
printf("输入进制数和整数:");
scanf("%d,%s",&m,&str);//逗号隔开
n=i_chg(str,m);

printf("10:%d\n",n);
memset(str1,0,sizeof(str1));
i_itoa(n,str1,2);
printf("2:%s\n",str1);
memset(str1,0,sizeof(str1));
i_itoa(n,str1,8);
printf("8:%s\n",str1);
memset(str1,0,sizeof(str1));
i_itoa(n,str1,16);
printf("16:%s\n",str1);

getch();
return 0;
}

[此贴子已经被作者于2007-9-17 11:47:54编辑过]


只有想不到,没有做不到
2007-09-17 11:03
HJin
Rank: 6Rank: 6
等 级:贵宾
威 望:27
帖 子:401
专家分:0
注 册:2007-6-9
收藏
得分:0 
回复:(青春小小雪)[求助][求助]急用!谢谢!

there are many methods to do the conversion, including the classic stack approach.

If you don't want to use any user-defind functions, you can try the following C++ code --- using C++ mainpulators and bulit-in methods.

The code is not perfect --- it has bugs for negative inputs.

程序代码:

#include <iostream>
#include <string>
using namespace std;

int main()
{
int radixOfInput;
int n;
string s;
char buffer[33];

// all inputs have to make a nonnegative integer
// i.e., there are bugs for negative inputs.
while(1)
{
cout<<\"Please choose a radix for your input\n\";
cout<<\"[ 0 --- decimal, 1 --- binary, 2 --- octal, 3 --- hexadecimal ]\n\";
cin>>radixOfInput;

switch(radixOfInput)
{
case 1:
cin>>s;
if(s.find_first_not_of(\"01\")!=string::npos)
{
cout<<\"invalid binary input.\n\";
continue;
}
else
{
n=strtol(s.c_str(), NULL, 2);
}
break;
case 2:
cin>>std::oct>>n;
break;
case 3:
cin>>std::hex>>n;
break;
case 0:
default:
cin>>n;
break;
}

itoa(n, buffer, 2);
printf(\"%s %d %o %x\n\", buffer, n, n, n);

cin.clear();
}

return 0;
}



I am working on a system which has no Chinese input. Please don\'t blame me for typing English.
2007-09-17 11:14
死了都要C
Rank: 4
来 自:四川成都
等 级:贵宾
威 望:13
帖 子:1582
专家分:116
注 册:2006-12-7
收藏
得分:0 
现在代码都出来了`````

我就不用了吧````


女施主``我给你``送茶来了```师太``你就从了老衲吧``
代码本天成~~~妙头偶得之```
2007-09-17 11:15
muse
Rank: 1
等 级:新手上路
帖 子:115
专家分:0
注 册:2007-9-13
收藏
得分:0 
在本论坛上就有现成的.

2007-09-17 13:24
muse
Rank: 1
等 级:新手上路
帖 子:115
专家分:0
注 册:2007-9-13
收藏
得分:0 

我刚刚还看到了.哎.


2007-09-17 13:25
vbnyng
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-3-10
收藏
得分:0 

可以通过一个switch ... case 选择机制,将你要转换的进制数输入,然后在每个case编算法,这样应该能解决问题的

2007-09-17 13:29
ysh0033
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2007-9-19
收藏
得分:0 

我来帮你编咯
#include <stdio.h>
void main()
{
printf(请您选择进制以及输入数值并把转换结果告诉我!)
  printf(比如你选择是十进制的18,如果你想换为2进制 请在纸上算出18的2进制表示是多少在输入)
  

2007-09-19 15:56
学技术的
Rank: 2
等 级:论坛游民
帖 子:91
专家分:45
注 册:2007-8-5
收藏
得分:0 
LS的,强!
2007-09-19 16:47
夜火
Rank: 1
等 级:新手上路
帖 子:149
专家分:0
注 册:2007-5-30
收藏
得分:0 

呵呵 不是学的 还想用 那就想拿 现成的 ???
神啊
掉下100万RMB 砸死我吧 !!


2007-09-19 16:52
快速回复:[求助][求助]急用!谢谢!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.012555 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved