Bubble Sort [ASM-MIPS]
# Program: Bubble sort
# Language: MIPS Assembly (32-bit)
# Arguments: 5 unordered numbers stored in $2 ~ $6 reg
# Author: brant-ruan
# Date: 2016-03-10
# IDE: MARS 4.5
# P.S.
# This program is one of my homework and the number of assembly instructions allowed is just 31.
# If I can use all the instructions of MIPS, optimizations will be considered.
# (E.g. The index() function should have been not necessary)
# Minds:
# It is not a good idea to store numbers from reg to mem. However, if using reg to sort directly,
# the program will be ridiculous for the regs can't be indexed as an array(Can they ?).
# My friend told me another brilliant idea that there's no need to swap $2 and $3, you can just store them to mem in the right order!!! Thanks!
######################################################################################################
.data
.word
array: 0, 0, 0, 0, 0
.text
# initialize $2 ~ $6
xor $2, $2, $2
xor $3, $3, $3
xor $4, $4, $4
xor $5, $5, $5
xor $6, $6, $6
add $2, $2, 7
add $3, $3, 4
add $4, $4, 8
add $5, $5, 13
add $6, $6, 2
# store values to be sorted into mem
sw $2, array+0
sw $3, array+4
sw $4, array+8
sw $5, array+12
sw $6, array+16
xor $5, $5, $5 # i
xor $6, $6, $6 # j
xor $7, $7, $7 # max_num
add $7, $7, 4 # max_num = 5 - 1 (the number of elements minus 1)
j begin
###############################################################################
# Sort procedure
sort:
# prototype: sort($2, $3)
# if $2 > $3 then swap($2, $3) else return
slt $4, $3, $2 # $4 is flag
beq $4, 0, sort_ret_src
xor $2, $2, $3
xor $3, $2, $3
xor $2, $2, $3
sort_ret_src:
j sort_ret_dst
###############################################################################
# Generate index procedure
index:
# For the data-type is word, we should generate 4*j as index
# prototype: index($12)
# if $30 is 0, store valid index in $9 and return to load_0, else store in $11 and return to load_1
xor $31, $31, $31 # count
xor $29, $29, $29 # valid index which will be returned
multiply:
beq $12, $31, ret # if count == $12, return
add $29, $29, 4 # $29 += 4
add $31, $31, 1 # count++
j multiply
ret:
beq $30, 1, ret_1 # judge return where
ret_0:
xor $9, $9, $9
add $9, $9, $29
j load_0
ret_1:
xor $11, $11, $11
add $11, $11, $29
j load_1
###############################################################################
begin:
beq $5, $7, end # if i == max_num, go to end
xor $10, $10, $10
add $10, $6, 1 # $10 is j+1
xor $12, $12, $12 # $12 is parameter of 'index' function
add $12, $12, $6 # deliver $6 (j) to $12
xor $30, $30, $30 # tell index() to return to load_0
j index
load_0:
lw $2, array($9) # load array[j] to $2 ($9 is index of j)
xor $12, $12, $12
add $12, $12, $10 # deliver $10 (j+1) to $12
xor $30, $30, $30
add $30, $30, 1 # tell index() to return to load_1
j index
load_1:
lw $3, array($11) # load array[j+1] to $3 ($11 is index of j+1)
j sort
sort_ret_dst:
sw $2, array($9) # store $2 into array[j]
sw $3, array($11) # store $3 into array[j+1]
add $6, $6, 1 # j++
sub $8, $7, $5 # $8 is (max_num - i)
bne $6, $8, next # if j < max_num-i, go to next
add $5, $5, 1 # i++
xor $6, $6, $6 # j = 0
next:
j begin
end:
# reload sorted array to $2 ~ $6
lw $2, array+0
lw $3, array+4
lw $4, array+8
lw $5, array+12
lw $6, array+16
Bubble Sort [ASM-MIPS]的更多相关文章
- Java中的经典算法之冒泡排序(Bubble Sort)
Java中的经典算法之冒泡排序(Bubble Sort) 神话丿小王子的博客主页 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一 ...
- Bubble Sort (5775)
Bubble Sort Problem Description P is a permutation of the integers from 1 to N(index starting from ...
- HDU 5775 Bubble Sort(冒泡排序)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- 2016 Multi-University Training Contest 4 Bubble Sort(树状数组模板)
Bubble Sort 题意: 给你一个1~n的排列,问冒泡排序过程中,数字i(1<=i<=n)所到达的最左位置与最右位置的差值的绝对值是多少 题解: 数字i多能到达的最左位置为min(s ...
- 快速幂取模 POJ 3761 bubble sort
题目传送门 /* 题意:求冒泡排序扫描k次能排好序的全排列个数 数学:这里有一个反序列表的概念,bj表示在j左边,但大于j的个数.不多说了,我也是看网上的解题报告. 详细解释:http://blog. ...
- 冒泡排序(Bubble Sort)
常见的排序算法有Bubble Sort.Merge Sort.Quick Sort 等,所有排序算的基本法思想都是把一个无限大的数据规模通过算法一步步缩小,指导最后完成排序. 这里分享一下Buuble ...
- [算法] 冒泡排序 Bubble Sort
冒泡排序(Bubble Sort,台湾另外一种译名为:泡沫排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没 ...
- HDU 5775 Bubble Sort (线段树)
Bubble Sort 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5775 Description P is a permutation of t ...
- c++算法联系,冒泡排序,bubble sort,插入排序,insert sort,
#include <iostream.h> #define MAX 100 void dispaly(int a[],int n) { for(int i=0;i<n;i+ ...
随机推荐
- SlimerJS – Web开发人员可编写 JS 控制的浏览器
SlimerJS 是一个提供给 Web 开发人员,可通过脚本编程控制的浏览器.它可以让你使用 Javascript 脚本操纵一个网页:打开一个网页,点击链接,修改的内容等,这对于做功能测试,页面自动机 ...
- PHP插入header('content-type:text/html;charset="utf-8')和error_reporting()
1.header PHP文件插入header("Content-type: text/html; charset=utf-8");相当于页面里面的<meta http-equ ...
- 【NodeJS 学习笔记01】不学就老了
前言 再不学nodeJs,我们就老了......在HTML5大浪袭来的时候,很多先辈就开始了NodeJs之旅,而那时我还在做服务器端的程序后来转成前端,和梯队的距离已经很大了,因为我会服务器端语言,还 ...
- SharePoint 2013 中如何使用Silverlight
1.打开VS,创建一个Silverlight程序,如下图: 2.配置选择默认的,当然也可以不勾选Host Application,如下图: 3.添加Silverlight控件,2个label和1个bu ...
- iOS/Android网络消息推送的实现两种方法
移动时代,用户为王,而每个APP拥有的活跃用户量(Active Users),决定了其价值. 消息推送成为了不可或缺的活跃唤起工具. 目前消息推送有如下两种途径: 1.iOS传统方式: 通过Apple ...
- sqlite之WAL模式
链接 概述 在3.7.0以后,WAL(Write-Ahead Log)模式可以使用,是另一种实现事务原子性的方法. WAL的优点 在大多数情况下更快 并行性更高.因为读操作和写操作可以并行. 文件IO ...
- IOS沙盒中的Documents、Library、tmp区别
1.Documents: 用户生成的文件.其他数据及其他程序不能重新创建的文件,iTunes备份和恢复的时候会包括此目录. 2.Library/Caches: 可以重新下载或者重新生成的数据,数据库缓 ...
- run() 和 start() 的区别
1) start: 用start方法来启动线程,真正实现了多线程运行,这时无需等待run方法体代码执行完毕而直接继续执行下面(指主线程下面)的代码.通过调用Thread类的start()方法来启动一个 ...
- C++ virtual虚函数
#include<iostream> using namespace std; class Base{ public: void m() { cout << "it' ...
- C语言的结构体和C++结构体的区别
关于C++中声明结构体中需要使用构造器创建实例对象的语法: <C++的结构体构造方法的基本概念:结构体的构造方法需要和结构体的名字相同,并且无返回值,也不要void关键字,这样的方法就是构造器的 ...