C编程-不使用+-*/等符合做数学运算

1. 不使用'+'号来计算两数之和

  1. 创建一个函数 addWithoutArithmetic,该函数接受两个整数 a 和 b 作为参数,代表要相加的两个两位数。
  2. 在 addWithoutArithmetic 函数中,使用一个循环来处理进位和相加操作,直到没有进位为止。
  3. 在循环中,首先计算进位 carry,这是通过执行按位与(&)运算来获得的。如果两个位同时为1,那么进位位会被设置为1。
  4. 接下来,执行异或(^)运算来得到无进位相加的结果,将结果存储在变量 a 中。异或操作的性质是,对于每一位,如果相加的两位相同,则结果为0;如果不同,则结果为1。
  5. 然后,将进位左移一位,将其加到 a 上,以模拟进位的效果。这是通过执行左移操作 carry << 1 来实现的。
  6. 循环会继续,直到没有进位为止,此时 b 变为0。
  7. 最后,返回 a,它包含了两位数相加的结果。
c 复制代码
#include <stdio.h>

int addWithoutArithmetic(int a, int b) {
    while (b != 0) {
        int carry = a & b;  // 计算进位
        a = a ^ b;          // 异或操作得到无进位相加的结果
        b = carry << 1;     // 左移进位,将其加到a上
    }
    return a;
}

int main() {
    int num1, num2;

    printf("请输入两个两位数(以空格分隔):");
    scanf("%d %d", &num1, &num2);

    int result = addWithoutArithmetic(num1, num2);

    printf("结果:%d\n", result);

    return 0;
}

2. 不使用'-'号做减法运算

c 复制代码
#include <stdio.h>

int subtractWithoutMinus(int a, int b) {
    while (b != 0) {
        // 计算借位
        int borrow = (~a) & b;
        // 异或运算得到不带借位的差值
        a = a ^ b;
        // 左移借位,将其加到a上
        b = borrow << 1;
    }
    return a;
}

int main() {
    int num1, num2;

    printf("请输入两个整数(以空格分隔):");
    scanf("%d %d", &num1, &num2);

    int result = subtractWithoutMinus(num1, num2);

    printf("差值:%d\n", result);

    return 0;
}
相关推荐
tobias.b34 分钟前
408真题解析-2010-6-数据结构-哈夫曼树
数据结构·计算机考研·408真题解析
tobias.b2 小时前
408真题解析-2010-7-数据结构-无向连通图
数据结构·算法·图论·计算机考研·408真题解析
良木生香3 小时前
【鼠鼠优选算法-双指针】003:快乐数 & 004:盛水最多的容器
算法
Cx330❀3 小时前
【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列
c++·算法
沃尔特。3 小时前
直流无刷电机FOC控制算法
c语言·stm32·嵌入式硬件·算法
CW32生态社区3 小时前
CW32L012的PID温度控制——算法基础
单片机·嵌入式硬件·算法·pid·cw32
Cx330❀3 小时前
【优选算法必刷100题】第038题(位运算):消失的两个数字
开发语言·c++·算法·leetcode·面试
漫随流水3 小时前
leetcode回溯算法(93.复原IP地址)
数据结构·算法·leetcode·回溯算法
燃于AC之乐3 小时前
我的算法修炼之路--5——专破“思维陷阱”,那些让你拍案叫绝的非常规秒解
c++·算法·贪心算法·bfs·二分答案·扩展域并查集·动态规划(最长上升子序列)
艾莉丝努力练剑3 小时前
【优选算法必刷100题】第021~22题(二分查找算法):山脉数组的峰顶索引、寻找峰值
数据结构·c++·算法·leetcode·stl