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;
}
相关推荐
凌波粒3 分钟前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
旖-旎9 分钟前
《LeetCode 417 太平洋大西洋水流问题 FloodFill DFS 解法》
c++·算法·深度优先·力扣·floodfill
凌波粒12 分钟前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
2zcode26 分钟前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
指令集梦境31 分钟前
图解:单调栈算法模板(Java语言)
java·开发语言·算法
生成论实验室1 小时前
自动驾驶:一个自主运动的系统
人工智能·算法·机器学习·语言模型·机器人·自动驾驶·安全架构
sheeta19981 小时前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger1 小时前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木1 小时前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法
Jasmine_llq1 小时前
《B4264 [GESP202503 四级] 二阶矩阵》
线性代数·算法·矩阵·二维矩阵遍历枚举所有2×2矩阵·交叉乘积等式条件判断·输入输出快读加速·长整型防溢出计数统计