我不知道是哪里出问题了,急急急
#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. 求大神帮我看看为啥会出现这问题? 就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;
} 1 根据二楼大神的代码,输入2得到4294967294是正确的,但是输入3结果应该是4294967295才对呀,为啥结果还是4294967294呢??????? 逻辑不对吧,题目贴出来看看。另外我也是一只小菜鸡。 0mrli0 发表于 2017-3-4 09:03
逻辑不对吧,题目贴出来看看。另外我也是一只小菜鸡。
就是二楼的那个代码 xiaa22663 发表于 2017-3-4 14:55
就是二楼的那个代码
我说的题目不是说的代码 0mrli0 发表于 2017-3-4 14:56
我说的题目不是说的代码
比如说输入2=00000000000000000000000000000010,要把1前面的零全部变成1,输出的结果就是4294967294=11111111111111111111111111111110。
再举个例子789=00000000000000000000001100010101,输出的数字是4294967061=11111111111111111111111100010101。
代码的问题是输入3的时候结果应该是4294967295,但是输出的却是4294967294 我解释的没错,不过循环次数少了一次
#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;
}
0mrli0 发表于 2017-3-5 12:02
我解释的没错,不过循环次数少了一次
感谢大神
页:
[1]