zoukankan
html css js c++ java
用C语言代码实现n进制数转换为十进制数
用C语言代码实现n进制数转换为十进制数
为了实现进制之间的相互转化,编程实现输入任意一个数并输入该数的进制,然后将其转换为10进制并输出。
主要思路是将输入的数存入一个一维数组中然后进行相应处理。
#include <stdio.h> #include <string.h> #include <stdlib.h> int main(void) { long t1; int i, n, t, t3; char a[100]; printf("请输入一个数:\n"); gets(a); //将输入的n进制的数储存在数组a中 strupr(a); //将数组中的小写字母转化为大写字母 t3 = strlen(a); //求出数组的长度 t1 = 0; printf("请输入转换的数的进制:\n"); //输入要转换的数的进制 scanf("%d", &n); for(i=0; i<t3; i++) { if(a[i] - '0' >= n && a[i] < 'A' || a[i] - 'A' + 10 >n ) //判断输入的数据和进制数是否符合 { printf("data error!!\n"); //错误 exit (0); } if(a[i] >='0' && a[i] <= '9') //判断是否为数字 t = a[i] - '0'; //求出该数字赋值给t else if (n >=11 && (a[i] >= 'A' && a[i] <= 'A' +n -10)) //判断是否为字母 t = a[i] - 'A' +10; //求出该字母所代表的十进制数 t1 = t1 *n +t; //求出最终转换成的10进制数 } printf("转化为的10进制数为 %ld\n", t1); return 0; }
查看全文
相关阅读:
Linq与Lambda,神一般的工作效率
svn和git孰优孰劣
关于C++的***5的输出问题
POJ 3469 Dual Core CPU(最小割)
HDU 4259 Double Dealing
最大流Dinic算法
HDU 4442 Physical Examination(2012年金华赛区现场赛A题)
int ,long , long long类型的范围
POJ 1679 The Unique MST(判断最小生成树是否唯一)
HDU 4280 Island Transport(网络流)
原文地址:https://www.cnblogs.com/linuxer/p/2441221.html
最新文章
怎么清空javascript数组[转载]
有寂寞,就有繁华
教大家如何玩转职场
不想再受骗?今天我们来谈谈那些年骗纸公司的骗钱套路
.NET面试题(一)
.NET面试题(三)
.NET面试题(二)
面试技巧
SQL SERVER性能调优之一(SQL SERVERL性能调优初探)
SQL SERVER性能调优之二(是否存在硬件瓶颈)
热门文章
C语言I博客作业03
大数据高性能数据库Redis在Windows上的使用教程
关于抽象工厂的一些理解
C#设计模式
spring.net框架配置和使用
Oracle数据库PL/SQL存储过程和函数的建立和调用
ASP.NET MVC项目框架快速搭建实战
ASP.NET MVC学习之Log4Net配置(日志记录)
CodeSmith自己动手写模板
利用EF和C#泛型实现通用分页查询
Copyright © 2011-2022 走看看