码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LC-3 机器语言 计算一个16位的字中有多少位是1


    计算机系统1的实验报告

    目录

    题目描述

    AC代码

    思路分析


    题目描述

    利用LC-3的机器代码计算一个16位的字中有多少位是‘1’。

    程序从x3000开始。

    需计算的字存储在x3100。

    计算的结果存储在x3101。

    AC代码

    1. 0011000000000000;PC=x3000
    2. 0101000000100000;AND R0<-0
    3. 0101001001100000;AND R1<-0
    4. 0001001001101000;ADD R1<-8
    5. 0001001001000001;ADD R1<-R1+R1
    6. 0010010011111011;LD R2<-M[x3100]
    7. 0001001001100000;ADD R1<-R1+0
    8. 0000010000000110;BRZ x300D
    9. 0001010010100000;ADD R2<-R2+0
    10. 0000011000000001;BRZP x300A
    11. 0001000000100001;ADD R0<-R0+1
    12. 0001010010000010;ADD R2<-R2+R2
    13. 0001001001111111;ADD R1<-R1-1
    14. 0000111111111000;BRNZP x3005
    15. 0011000011110011;ST M[x3101]<-R0

    思路分析

    程序总体设计

    问题是计算一个16位的字中有多少位是‘1’,初步思考一下,解决这个问题需要进行计数,判断是不是‘1’,以及一个16次的循环。

    用R0作为计数器,R1控制循环的次数,R2存储需要判断的字。

    先用AND指令让R0和R1赋值为0,接着需要让R1的值为16,因为ADD指令的立即数寻址模式imm5只能表示-16到15,所以不能直接把16赋值给R1,我的方法是先把8赋值给R1,即用ADD指令让R0=R0+8,之后用ADD指令让R0=R0+R0,即可让R0的值为16。后用LD指令把内存地址为x3100的内容读进R2。主要问题即计算字中有多少个是‘1’,我采取的方法是通过判断R2的值的正负来确定,如果是负数,那么第一位就是‘1’,之后使其乘2,即让其各位左移一位,再次重复判断第一位,直到累计判断了16次。

    最后用ST指令把R0的值存进地址为x3101的内存单元。

    核心数据结构

    核心变量有三个,R0作为计数器,负责计数字中为1的个数,R1控制循环的次数,从16开始自减,R2存储需要判断的字,每一次循环之后都做一次与自己相加的操作。

    程序一开始,先让R0和R1赋值为0,即与0相与,然后让R1赋值为8,之后R1做一次与自己相加的操作使其值变成16,之后把内存地址为x3100的数据存进R2。

    在主循环中,通过判断R2是否是负数来计数,如果是负数,那么让R0自增,之后让R2与自己相加,然后让R1自减。

    最后把R0的值存进内存地址为x3101的内存单元。

  • 相关阅读:
    14_Nginx正则表达式_动静分离配置
    字节测试总监8年测试路,如何从功能测试转成自动化测试——愿测试人不再迷茫
    【PTA】递归练习_输出1到n的全排列
    Vue工程化中创建全局组件、extend创建组件、extends配置组件、异步组件
    STM32:串口发送
    【干货】【全网最全】【全网最详细】 javaWeb关于Thymeleaf+SpringBoot 的学习教程,看这一篇就够了。
    .net8 blazor auto模式很爽(五)读取sqlite并显示(2)
    vivo大规模 Kubernetes 集群自动化运维实践
    Java语法 实现BCH校验算法
    力扣第 387 场周赛第四题 将元素分配到两个数组中 II 二分查找,离散化,线段树
  • 原文地址:https://blog.csdn.net/weixin_62264287/article/details/126390903
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号