xiaa22663 发表于 2017-3-2 11:22:31

我不知道是哪里出问题了,急急急

#include <stdio.h>
#include <math.h>
    //输入 2 = 00000000 00000000 00000000 00000010
    //输出 4294967294 = 11111111 11111111 11111111 11111110
   
int main(void){

int num_binary = {0}, index;
unsigned int num, i, j = 32, a;
double count, total;

scanf("%u", &num);
while(num){
    a = num % 2;
    num_binary = a;
    num = num / 2;
    j--;
}

for(i = 0;i < j;i++){
    if(num_binary==0){
      num_binary = 1;
    }
    else{
      break;
    }
}

for(index=0;index<j;index++){
    count = num_binary * pow(2, j);
    total += count;
    j--;
}
printf("%u\n", (unsigned int)total);
}


按理说输出应该是4294967294,但是我这个输出的是2147418112. 求大神帮我看看为啥会出现这问题?

0mrli0 发表于 2017-3-2 13:50:46

就1个 j 值在变化,看代码有解释,如下。 另外可以学一下调试,这种错误调试一下一目了然
#include <stdio.h>
#include <math.h>
    //输入 2 = 00000000 00000000 00000000 00000010
    //输出 4294967294 = 11111111 11111111 11111111 11111110

int main(void){

int num_binary = {0}, index;
unsigned int num, i, j = 32, a;
double count, total;

scanf("%u", &num);
while(num){
    a = num % 2;
    num_binary = a;
    num = num / 2;
    j--;
}//此处j值已经改变并非32

for(i = 0;i < 32;i++){   //虽然此处用j不影响结果但是不符合逻辑
    if(num_binary==0){
      num_binary = 1;
    }
    else{
      break;
    }
}
   j = 32;
for(index=0;index<31;index++){       //循环范围是0-31,j在变化
    j--;
    count = num_binary * pow(2, j);
    total += count;

}
printf("%u\n", (unsigned int)total);
return 0;
}

sxr2912719 发表于 2017-3-2 14:50:30

1

xiaa22663 发表于 2017-3-3 21:19:49

根据二楼大神的代码,输入2得到4294967294是正确的,但是输入3结果应该是4294967295才对呀,为啥结果还是4294967294呢???????

0mrli0 发表于 2017-3-4 09:03:26

逻辑不对吧,题目贴出来看看。另外我也是一只小菜鸡。

xiaa22663 发表于 2017-3-4 14:55:00

0mrli0 发表于 2017-3-4 09:03
逻辑不对吧,题目贴出来看看。另外我也是一只小菜鸡。

就是二楼的那个代码

0mrli0 发表于 2017-3-4 14:56:31

xiaa22663 发表于 2017-3-4 14:55
就是二楼的那个代码

我说的题目不是说的代码

xiaa22663 发表于 2017-3-5 01:22:57

0mrli0 发表于 2017-3-4 14:56
我说的题目不是说的代码

比如说输入2=00000000000000000000000000000010,要把1前面的零全部变成1,输出的结果就是4294967294=11111111111111111111111111111110。
再举个例子789=00000000000000000000001100010101,输出的数字是4294967061=11111111111111111111111100010101。
代码的问题是输入3的时候结果应该是4294967295,但是输出的却是4294967294

0mrli0 发表于 2017-3-5 12:02:18

我解释的没错,不过循环次数少了一次
#include <stdio.h>
#include <math.h>
    //输入 2 = 00000000 00000000 00000000 00000010
    //输出 4294967294 = 11111111 11111111 11111111 11111110

int main(void){

int num_binary = {0}, index;
unsigned int num, i, j = 32, a;
double count, total;

scanf("%u", &num);
while(num){
    a = num % 2;
    num_binary = a;
    num = num / 2;
    j--;
}//此处j值已经改变并非32

for(i = 0;i < 32;i++){   //虽然此处用j不影响结果但是不符合逻辑
    if(num_binary==0){
      num_binary = 1;
    }
    else{
      break;
    }
}
   j = 32;
for(index=0;index<32;index++){       //循环范围是0-31,j在变化
    j--;
    count = num_binary * pow(2, j);
    total += count;

}
printf("%u\n", (unsigned int)total);
return 0;
}

xiaa22663 发表于 2017-3-6 01:30:05

0mrli0 发表于 2017-3-5 12:02
我解释的没错,不过循环次数少了一次

感谢大神
页: [1]
查看完整版本: 我不知道是哪里出问题了,急急急