实训10

#include<stdio.h>
int main()
{
    int  er[10],ba[10]={0},shiliu[10];
    int n,t,c,i;
    printf("请输入你需要输入的二进制中含有的数的个数每个数用空格隔开:");
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
        scanf("%d",&er[i]);
    }
    int y=2;
    for(i=n-1;i>=0;i--)/*将二进制转换为十进制*/
    {
      if(i==(n-1))
      {
      t=(er[i])*1;
      }
      else
      {
      t=t+(er[i])*y;
      y=y*2;
      }

    }
    int g=t;
    printf("\n转换后的八进制为:");
    i=0;
    while(t>0)/*将十进制转换为八进制*/
    {
        c=t%8;
        t=t/8;
        ba[i]=c;
        i++;
    }
    int x=i;
    for(i=x-1;i>=0;i--)
    {
        printf("%d",ba[i]);
    }
    i=0;
    while(g>0)/*将十进制转换为十六进制*/
    {
        c=g%16;
        g=g/16;
        shiliu[i]=c;
        i++;
    }
    int w=i;
    printf("\n转换后的十六进制为:");
    for(i=w-1;i>=0;i--)
    {
        if(shiliu[i]<10)
        {
            printf("%d",shiliu[i]);
        }
        else if(shiliu[i]==15)
        {
            printf("F");
        }
        else if(shiliu[i]==14)
        {
            printf("E");
        }
        else if(shiliu[i]==13)
        {
            printf("D");
        }
        else if(shiliu[i]==12)
        {
            printf("C");
        }
        else if(shiliu[i]==11)
        {
            printf("B");
        }
        else if(shiliu[i]==10)
        {
            printf("A");
        }
    }
return 0;
}

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ArrayList类是Java中内置的动态数组类,它能够自动调整大小以适应存储的数据量。在程序设计二的实训10中,要求我们实现一个复杂类,而这个类使用ArrayList类来存储数据。 实现ArrayList类需要考虑以下几个方面: 1. 封装内部数组:我们需要在类中创建一个私有的数组来存储数据。为了保证封装性,这个数组应该是私有的,只能通过类的方法来访问和修改。 2. 动态调整数组大小:由于ArrayList类需要能够动态调整大小,我们需要在类中添加方法来检查数组是否已满,如果已满则创建一个更大的数组并将原有数据复制到新数组中。 3. 添加元素:为了方便使用,我们需要在类中添加方法来向数组中添加元素。在添加元素时,我们需要检查数组是否已满,如果已满则先调整数组大小后再添加元素。 4. 删除元素:同样地,我们需要在类中添加方法来删除数组中的元素。删除元素时,我们需要将后续的元素依次向前移动,并更新数组的大小。 5. 获取元素:为了方便使用,我们还需要在类中添加方法来获取数组中的元素。可以根据下标来获取指定位置的元素。 6. 其他方法:除了上述基本操作外,还可以根据需要添加其他方法,比如获取数组的大小、判断数组是否为空等。 总之,实现ArrayList类需要我们对动态数组的特性及其操作有较深入的理解。通过封装内部数组、动态调整数组大小以及实现基本的增删查操作,我们可以完成ArrayList类的实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值