梦回连营 发表于 2021-11-16 18:52:58

C位运算

如图所示,利用位运算完成整数加法,为什么我自己运行没问题,提交后会显示这么一个问题???

人造人 发表于 2021-11-16 19:07:16

把int改成unsigned int试试
还有,发代码

梦回连营 发表于 2021-11-16 19:10:50

人造人 发表于 2021-11-16 19:07
把int改成unsigned int试试
还有,发代码

int add(int a, int b){
    int ans = 0;
    int jw = 0;
    for (int i = 0; i <= 31; i++){
      unsigned int a_t = (1 << i) & a;
      unsigned int b_t = (1 << i) & b;
      ans = ans | (a_t ^ b_t ^ jw);
      jw =( (jw == 0) ? (a_t & b_t) : (a_t | b_t) ) << 1;
    }
    return ans;
}

试过了,还是不行。发图片是因为这代码在我自己的电脑上运行没问题的,提交给leetcode就出现这个问题了。

梦回连营 发表于 2021-11-16 19:22:04

梦回连营 发表于 2021-11-16 19:10
试过了,还是不行。发图片是因为这代码在我自己的电脑上运行没问题的,提交给leetcode就出现这个问题 ...

leetcode 剑指Offer65题

人造人 发表于 2021-11-16 21:39:23

梦回连营 发表于 2021-11-16 19:10
试过了,还是不行。发图片是因为这代码在我自己的电脑上运行没问题的,提交给leetcode就出现这个问题 ...

让你发代码,是因为我不想照着图片抄一遍代码
代码发完整

人造人 发表于 2021-11-16 21:40:54

梦回连营 发表于 2021-11-16 19:22
leetcode 剑指Offer65题

说这个没用,我很难去到这个位置来使用这个环境调试程序

梦回连营 发表于 2021-11-17 10:18:44

人造人 发表于 2021-11-16 21:40
说这个没用,我很难去到这个位置来使用这个环境调试程序

#include <stdio.h>

int main(void){
    unsigned int b = (1 << 32);
    printf("%u\n", b);
    return 0;
}

这段代码也会出现警告,我想知道有什么办法可以存储 1 << 32 位或者左移更高位的数并能打印出来。

人造人 发表于 2021-11-17 11:59:17

梦回连营 发表于 2021-11-17 10:18
这段代码也会出现警告,我想知道有什么办法可以存储 1

没明白你的意思,这样?
#include <stdio.h>

int main(void){
    size_t count = 128;
    int b = (1 << (count % 32));
    printf("%u\n", b);
    return 0;
}

ljasondon 发表于 2021-11-17 23:54:33

unsigned __int128
页: [1]
查看完整版本: C位运算