吉士先生 2022-07-11 11:37 采纳率: 100%
浏览 28
已结题

【c++中for循环怎么调用动态数组?】调用数组中第二个元素时会出现乱码。

#include
using namespace std;
#include
int main()
{
int sum = 0, sum1 = 0, n;
int *p;
cout << "请输入二进制的长度:" << endl;
cin >> n;
p = new int[n];
cout << "请输入一个二进制的数字:" << endl;
cin >> *p;
int s1 = { 0 };
for (int i = 0; i < n; i++)
{
if (p[i] == 0) //这边老是跳过第一个判断语句,直接进行第二个语句
{
sum = sum + 1;
}
else
{
sum1 = sum1 + 2;
}
cout << *p << "转换成十进制后为:" << sum + sum1 << endl;
}
delete[]p;
return 0;
}

img

  • 写回答

2条回答 默认 最新

  • a5156520 2022-07-11 11:53
    关注

    应该是获取二进制数字到数组那里不对,然后根据数组内容把对应的二进制转为十进制的算法也需要改正,下面是一个实现,供参考:
    参考链接:
    位进制是什么意思_百度知道

    
    #include <iostream> 
    using namespace std;
    
    int main()
    {
        int sum = 0, sum1 = 0, n;
        int *p;
        cout << "请输入二进制的长度:" << endl;
        cin >> n;
        p = new int[n];
        
        cout << "请输入一个二进制的数字:" << endl;
        //获取n个数字输入到数组 
        for(int i=0;i<n;i++){
                cin >> p[i];
        }
    
        
    //    for(int i=0;i<n;i++){
    //        cout<<p[i];
    //    }
    //    cout<<endl;
        
        int s1 = { 0 };
        
        int weight=1;  //每一位的位权值 ,此为二进制数组最右边的数的位权值 
        for (int i = n-1; i >=0 ; i--)
        {
            //
            if (p[i] == 1) //这边老是跳过第一个判断语句,直接进行第二个语句
            {
                sum+= weight; //因为二进制每一位只有0和1,所以如果当前数不是0,加上他的位权值就可以了 
            }
            
            weight*=2;  //下一个数位的位权值 
    
            
            cout << *p << "转换成十进制后为:" << sum<< endl;
        }
        
        delete[]p;
        return 0;
    }
    
    

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 7月19日
  • 已采纳回答 7月11日
  • 创建了问题 7月11日

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥15 如何修改pca中的feature函数
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况