Coursera 学习记录:计算机组成上机作业(利用系统功能调用实现字符串的查找比较)

题目如下:字符串查找比较利用系统功能调用从键盘输入一个字符串,然后输入单个字符,查找该字符串中是否有该字符(区分大小写)。具体要求如下:(1) 如果找到,则在屏幕上显示:Success! Location: X其中,X为该字符在字符串中第一次出现的位置(2) 如果没找到,则在屏幕上显示:Fail!(3) 输入一个字符串后,可以反复输入希望查询的字符,直到按“?”键结...
摘要由CSDN通过智能技术生成

题目如下:

字符串查找比较

利用系统功能调用从键盘输入一个字符串,然后输入单个字符,查找该字符串中是否有该字符(区分大小写)。具体要求如下:

(1) 如果找到,则在屏幕上显示:

Success! Location: X

其中,X为该字符在字符串中第一次出现的位置

(2) 如果没找到,则在屏幕上显示:

Fail!

(3) 输入一个字符串后,可以反复输入希望查询的字符,直到按“?”键结束程序

(4) 每个输入字符独占一行,输出查找结果独占一行,位置编码从1开始。

提示:为避免歧义,字符串内不包含"?"符号

格式示例如下:

abcdefgh

a

Success! Location: 1

x

Fail!

解题思路:

slt rd,rs,rt # 有符号的比较,if(rs<rt) rd=1 else rd=0
 
sub rd,rs,rt # 有符号相减,rd=rs-rt
 
add rd,rs,rt # 与, rd=rs&rt

addi rt,rs,imm 

addi $21,$22,-50 # $21=$22+(-50)

# rs = 22 源操作数寄存器编号
# rt = 21 目的操作数寄存器编号
immediate = -50 立即数
 
# 分支指令
 
beq rs,rt,imm # 相等则分支
 
bne rs,rt,imm # 不相等分支
 
beq reg1,reg2,L1
 
# if (value in reg1) 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值