第十七周上机实践项目——数组用于进制转换

来源:互联网 发布:牧场数据信息管理平台 编辑:程序博客网 时间:2024/06/05 20:14
* Copyright (c) 2013, 烟台大学计算机学院 * All rights reserved. * 作    者:  刘中林 * 完成日期:2013 年  12月 26 日 * 版 本 号:v1.0 * 问题描述:数组的排序 * 输出:十进制数1000分别转换成8进制、24进制和2进制数,数中最大数是多少,在此数的第几位。 */#include <iostream>using namespace std;void tran(int n, int d);int main(){    tran(1000, 8);    tran(1000, 24);    tran(1000, 2);    return 0;}void tran(int n, int d){    int k,a[100],m=0,max,i;    k=n;   //下面完成对n(即k)的进制转换    while(k>0)    {        a[m++]=k%d;        k/=d;    }    //由于k用作了n的替身,n在这时还能得以保证其原值    //转换完的d进制数有m位    //输出d进制数,同一循环中求各位中的最大值    max=0;    cout<<n<<"转换为"<<d<<"进制数为:";    for(i=m-1; i>=0; i--)    {        if(a[i]<10)            cout<<a[i];        else            cout<<char('A'+a[i]-10);        if(max<a[i]) max=a[i];    }    cout<<endl;    //下面的循环输出第几位上出现了max    cout<<"各位数中的最大值是 " << ((max<10)?char('0'+max):char('A'+max-10)) << ",出现在第 ";    for(i=m-1; i>=0; i--)    {        if(a[i]==max)            cout<<m-i<<' '; //i=m-1时, m-i为1,第1位即最大,依此类推    }    cout <<"位上。"<<endl;}


*样例输出:

*心得体会。。。。

0 0