1、代码

2、编译

3、运行


1、代码框架 /home/fengbo/sorter

$ tree
.
├── bin
├── pkg
├── readme.txt
└── src
├── algorithms
│   ├── bubblesort
│   │   ├── bubblesort.go
│   │   └── bubblesort_test.go
│   └── qsort
│   ├── qsort.go
│   └── qsort_test.go
└── sorter
└── sorter.go

  1.1、src/algorithms/bubblesort/bubblesort.go

//bubblesort.go
package bubblesort func BubbleSort(values []int) {
flag := true for i := 0; i < len(values) - 1; i++ {
flag = true for j := 0; j < len(values) - i - 1; j++ {
if values[j] > values[j + 1] {
values[j], values[j + 1] = values[j + 1], values[j]
flag = false
}
if flag == true {
break;
}
}
}
}

  1.2、src/algorithms/bubblesort/bubblesort_test.go

//bubble_test.ho
package bubblesort import "testing" func TestBubbleSort1(t * testing.T) {
values := []int {5, 4, 3, 2, 1}
BubbleSort(values)
for i := 0; i < len(values) - 1; i++ {
if values[i] > values[i + 1] {
t.Error("ubbleSort() faild. Got at ", values[i], values[i + 1])
break
}
}
} func TestBubbleSort2(t * testing.T) {
values := []int{5}
BubbleSort(values)
if(values[0] != 5) {
t.Error("BubbleSort() faild. Got ", values, "Excepted 5")
}
}

  1.3、src/algorithms/qsort/qsort.go

//qsort.go
package qsort func quickSort(values []int, left, right int) {
temp := values[left]
p := left
i, j := left, right for i <= j {
for j >= p && values[j] >= temp {
j--
}
if j >= p {
values[p] = values[j]
p = j
}
if values[i] <= temp && i <= p {
i++
} if i <= p {
values[p] = values[i]
p = i
}
}
values[p] = temp
if p - left > 1 {
quickSort(values, left, p - 1)
}
if right - p > 1 {
quickSort(values, p + 1, right)
}
} func QuickSort(values []int) {
quickSort(values, 0 , len(values) - 1)
}

  1.4、src/algorithms/qsort/qsort_test.go

//qsort_test.go
package qsort import "testing" func TestQuickSort1(t * testing.T) {
values := []int {5, 4, 3, 2, 1}
QuickSort(values)
var i int;
var j int = len(values) - 1
for i = 0; i < j; i++ {
if values[i] > values[i + 1] {
t.Error("QuickSort() faild")
break;
}
}
} func TestQuickSort2(t * testing.T) {
values := []int {5}
QuickSort(values)
if values[0] != 5 {
t.Error("QuickSort() faild. Got", values);
}
}

  1.5、src/sorter/sorter.go

package main

import "bufio"
import "flag"
import "fmt"
import "io"
import "os"
import "strconv"
import "time" import "algorithms/bubblesort"
import "algorithms/qsort" var infile * string = flag.String("i", "unsorted.dat" , "File contains values for sorting")
var outfile * string = flag.String("o", "sorted.dat" , "File to receive sorted values")
var algorithm * string = flag.String("a", "qsort" , "Sort algorithm") func readValues(infile string)(values []int, err error){
file, err := os.Open(infile)
if err != nil{
fmt.Println("Failed to open the input file :", infile)
return
}
defer file.Close() br := bufio.NewReader(file) values = make([]int, 0) for{
line, isPrefix, err1 := br.ReadLine() if err1 != nil{
if err1 != io.EOF{
err = err1
}
break
}
if isPrefix {
fmt.Println("A too long line, seems unexpected.")
return
} str := string(line) value, err1 := strconv.Atoi(str) if err1 != nil{
err = err1
return
} values = append(values, value)
}
return
} func writeValues(values []int, outfile string) error {
file, err := os.Create(outfile)
if err != nil {
fmt.Println("Faild to create the outfile ", outfile)
return err
} defer file.Close() for _, value := range values {
str := strconv.Itoa(value)
file.WriteString(str + "\n")
} return nil
} func main(){
flag.Parse() if infile != nil {
fmt.Println("infile =", *infile, "outfile = ", *outfile, "algorithm = ", *algorithm)
} values, err := readValues(*infile) if err == nil {
t1 := time.Now()
switch *algorithm {
case "qsort" :
qsort.QuickSort(values)
case "bubblesort" :
bubblesort.BubbleSort(values)
default :
fmt.Println("Sorting algorithm", * algorithm, "is either unknown or ensupported.")
}
t2 := time.Now() fmt.Println("The sorting process costs", t2.Sub(t1), "to complete.")
writeValues(values, * outfile)
}else {
fmt.Println(err)
}
}

2、编译

  2.1、设置环境变量

[fengbo@sorter]$ pwd
/home/fengbo/sorter
[fengbo@sorter]$ export GOPATH="/home/fengbo/sorter"

  2.1编译级安装

$ go build algorithms/bubblesort
$ go build algorithms/qsort
$ go install algorithms/bubblesort
$ go install algorithms/qsort
$ go build sorter

  2.2、编译及安装后的目录结构

$ tree
.
├── bin
├── pkg
│   └── linux_386
│   └── algorithms
│   ├── bubblesort.a
│   └── qsort.a
├── readme.txt
├── sorter
└── src
├── algorithms
│   ├── bubblesort
│   │   ├── bubblesort.go
│   │   └── bubblesort_test.go
│   └── qsort
│   ├── qsort.go
│   └── qsort_test.go
└── sorter
└── sorter.go

3、运行

  3.1、未排序的文本文件

$ cat unsorted.dat
6
345
76564
5
66
443654
757
2365
565

  3.2、运行排序程序

$ ./sorter -i unsorted.dat -o sorted.dat -a qsort
infile = unsorted.dat outfile = sorted.dat algorithm = qsort
The sorting process costs 2.22us to complete.

  3.3、排序后的结果文件

$ ls
sorted.dat sorter unsorted.dat
$ cat sorted.dat
5
6
66
345
565
757
2365
76564
443654

4、注释

  代码来源于《Go语言编程》一书的第二章,目录结构与原书有些差异。

GO语言练习:第一个Go语言工程--排序的更多相关文章

  1. 李洪强iOS开发之【零基础学习iOS开发】【02-C语言】02-第一个C语言程序

    前言 前面已经唠叨了这么多理论知识,从这讲开始,就要通过接触代码来学习C语言的语法.学习任何一门语言,首先要掌握的肯定是语法.学习C语言语法的目的:就是能够利用C语言编写程序,然后运行程序跟硬件(计算 ...

  2. D、GO、Rust 谁会在未来取代 C?为什么?——Go语言的定位非常好,Rust语言非常优秀,D语言也不错

    不要管我的地位和 D 语言创造者之一的身份.我会坦诚的回答这个问题.我熟悉 Go 和 Rust,并且知道 D 的缺点在哪里.我鼓励人们在 Rust 和 Go 社区相似身份的人,也可以提出他们诚恳的观点 ...

  3. iOS_02_第一个C语言程序(理解编译、连接、运行)

    一.开发工具的选择 1. 可以用来写代码的工具:记事本.ULtraEdit.Vim.Xcode等. 2. 选择XCode的原因:苹果公司官方提供的开发利器.简化开发的工程.有高亮显示功能. 3. 使用 ...

  4. 第一个C语言程序

    从第一个C语言程序了解C语言 了解关键字 了解函数 注释 C语言的执行流程 标识符 C语言的学习重难点 从第一个C语言程序了解C语言 上图是一个在控制台上显示“Hello, World!”的C语言源代 ...

  5. Swift3.0语言教程获得一个公共的前缀

    Swift3.0语言教程获得一个公共的前缀 Swift3.0语言教程获得一个公共的前缀,当在一个程序中有多个字符串时,我们需要判断是否有两个字符串有公共的前缀时,是很困难的.在NSString中的co ...

  6. php调用一个c语言写的接口问题

    用php调用一个c语言写的soap接口时,遇到一个问题:不管提交的数据正确与否,都无法请求到接口 1.用php标准的soap接口去请求 2.拼接xml数据去请求 以上两种方式都不正确 解决办法:php ...

  7. 机器学习(一) 从一个R语言案例学线性回归

    写在前面的话 按照正常的顺序,本文应该先讲一些线性回归的基本概念,比如什么叫线性回归,线性回规的常用解法等.但既然本文名为<从一个R语言案例学会线性回归>,那就更重视如何使用R语言去解决线 ...

  8. 采用 PAT工具及CSP语言,对一个问题进行自动机 建模

    pat是新加坡国立开发的工具,需要的去官网下http://www.comp.nus.edu.sg/~pat/ ,学了一天,是个不错的自动机验证工具,感觉还不错啊. 验证一个数是否为斐波那契数且为质数 ...

  9. 第一个C语言编译器是怎样编写的?

    首先向C语言之父Dennis MacAlistair Ritchie致敬! 当今几乎所有的实用的编译器/解释器(以下统称编译器)都是用C语言编写的,有一些语言比如Clojure,Jython等是基于J ...

  10. C语言学习-01第一个C语言程序

    一 C语言的历史 C语言是一门通用计算机编程语言,应用广泛.C语言的设计目标是提供一种能以简易的方式编译.处理低级存储器.产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言. 尽管C语言提供 ...

随机推荐

  1. Juery Ajax语法

    $.ajax({ url: "/ForgetCard/ForgetLogin",//方法路径URL data: { strUser: $("#textUser" ...

  2. [Oracle] PL/SQL学习笔记

    -- 1. 使用一个变量 declare -- Local variables here v_name ); begin -- Test statements here select t.user_n ...

  3. 【译】安装Sonar要求

    本文仅为本人看sonar官方文档时,因其为英文,故简单整理翻译[英语不好,见谅!] http://docs.sonarqube.org/display/SONAR/Requirements   目录 ...

  4. IplImage, CvMat, Mat 的关系

    IplImage, CvMat, Mat 的关系 转载来源:http://www.cnblogs.com/summerRQ/articles/2406109.html opencv中常见的与图像操作有 ...

  5. scrollTo , scrollBy区别

    View视图中scrollTo 与scrollBy这两个函数的区别 . 首先 ,我们必须明白在Android View视图是没有边界的,Canvas是没有边界的,只不过我们通过绘制特定的View时对 ...

  6. Java学习随笔3:遍历文件夹及文件的读取和写入

    import java.io.File; /** * 遍历文件夹 */ public class ScannerFile { public static void main(String[] args ...

  7. Hadoop RPC机制的使用

    一.RPC基础概念 1.1 RPC的基础概念 RPC,即Remote Procdure Call,中文名:远程过程调用: (1)它允许一台计算机程序远程调用另外一台计算机的子程序,而不用去关心底层的网 ...

  8. banner无限轮播

    activity_main.xml <?xml version="1.0" encoding="utf-8"?> <RelativeLayou ...

  9. express-10 表单处理

    从用户那里收集信息的常用方法就是使用HTML表单.无论是使用浏览器提交表单,还是使用AJAX提交,或是运用精巧的前端控件,底层机制通常仍旧是HTML表单. 向服务器发送客户端数据 向服务器发送客户端数 ...

  10. DOM--3 DOM核心和DOM2 HTML(1)

    网页是一种结构化的文档,使用一组预定义的XML和HTML标签进行标记:当浏览器接受到网页文档时,会根据文档类型和关联的样式表对其进行解析,然后以可视化形式显示在屏幕上. DOM是一组用来描述脚本怎样与 ...