1.编写程序,在终端输出九九乘法表。

package main

import (
"fmt"
) func main() {
for i := 1; i <= 9; i++ {
for j := 1; j <= i; j++ {
fmt.Printf("%d*%d=%d%s", j, i, i*j, "\t")
}
fmt.Printf("%s", "\n")
}
}

2.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如 1x6=6 2X3=6 1+2+3=6 1*28=28 2*14=28 4*7=28 1+2+4+7+14=28。编程找出1000以内的所有完数。

思路:先求因子数,所有和n去余等于0的为该数的因子。 因子相加等于n的为完数

package main

import (
"fmt"
) func calc(n int) bool {
var sum int for i := 1; i < n; i++ {
if n%i == 0 {
sum += i
}
}
return n == sum
} func wanshu(n int) {
for j := 1; j <= n; j++ {
if calc(j) {
fmt.Println(j)
}
}
} func main() {
var a int
fmt.Scanf("%d", &a)
wanshu(a)
}

 

3.输入一个字符串,判断其是否为回文。回文字符串是指从左到右读和从右到左读完全相同的字符串。

思路

1 判断回文需要比较 str[0]与 str[len-1]  str[1] str[len-1-1]......是否相同

2 判断不超过该字符串的长度的一半

3 在go语言中需要判断中文和英文所占用的字符数

golang byte rune区别参考:https://blog.csdn.net/HaoDaWang/article/details/79971395

package main

import (
"fmt"
) func judge(str string) bool { s := []rune(str) for key, _ := range s {
if key == int(len(s)/2) {
break
} last := len(s) - key - 1 if s[key] != s[last] {
return false
}
} // for n := 0; n < len(str); n++ {
// if n == int(len(str)/2) {
// break
// }
// last := len(str) - n - 1
// if str[n] != str[last] {
// return false
// }
// } return true
} func main() {
var str1 string
fmt.Scanf("%s", &str1)
result := judge(str1) if result {
fmt.Println("完数")
} else {
fmt.Println("不是完数")
}
}

4.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

5.计算两个大数相加的和,这两个大数会超过int64的表示范围

按照计算加法的方式将字符串拆成每个字符进行计算,如果和大于10则进位,并且将和10取余得到该为的数,最后将每个字符串拼接成一个,最后将最后一位的进位和字符串拼接即可。

package main

import (
"bufio"
"fmt"
"os"
"strings"
) func calc(str1, str2 string) (res string) {
if len(str1) == 0 && len(str2) == 0 {
res = "0"
return
} var index1 = len(str1) - 1
var index2 = len(str2) - 1
var tmp int for index1 >= 0 && index2 >= 0 {
f1 := str1[index1] - '0'
f2 := str2[index2] - '0' sum := int(f1) + int(f2) if sum >= 10 {
tmp = 1
} else {
tmp = 0
} num := sum%10 + '0'
res = fmt.Sprintf("%c%s", num, res)
index1--
index2--
} for index1 >= 0 {
f1 := str1[index1] - '0' sum := int(f1) + tmp if sum >= 10 {
tmp = 1
} else {
tmp = 0
} num := sum%10 + '0'
res = fmt.Sprintf("%c%s", num, res)
index1--
} for index2 >= 0 {
f2 := str2[index2] - '0'
sum := int(f2) + tmp if sum >= 10 {
tmp = 1
} else {
tmp = 0
} num := sum%10 + '0'
res = fmt.Sprintf("%c%s", num, res)
index2--
} if tmp == 1 {
res = fmt.Sprintf("%d%s", 1, res)
}
return
} func main() {
read := bufio.NewReader(os.Stdin)
result, _, err := read.ReadLine() if err != nil {
fmt.Printf("read from cmd: %s", err)
return
} strslice := strings.Split(string(result), "+") fmt.Println(calc(strings.TrimSpace(strslice[0]), strings.TrimSpace(strslice[1])))
}

go函数练习的更多相关文章

  1. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  2. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  3. JavaScript权威指南 - 函数

    函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...

  4. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  5. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  6. javascript中的this与函数讲解

    前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...

  7. 复杂的 Hash 函数组合有意义吗?

    很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...

  8. JS核心系列:浅谈函数的作用域

    一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...

  9. C++中的时间函数

    C++获取时间函数众多,何时该用什么函数,拿到的是什么时间?该怎么用?很多人都会混淆. 本文是本人经历了几款游戏客户端和服务器开发后,对游戏中时间获取的一点总结. 最早学习游戏客户端时,为了获取最精确 ...

  10. Python高手之路【四】python函数装饰器

    def outer(func): def inner(): print('hello') print('hello') print('hello') r = func() print('end') p ...

随机推荐

  1. TDD中测试替身学习总结

    在使用TDD开发时,经常会遇到需要被测对象需要依赖其他子系统的情况,但是你希望将测试代码跟依赖项隔离,以保证测试代码仅仅针对当前被测对象或方法展开,这时候你需要的是测试替身.测试替身可以分为四类:- ...

  2. Ping命令的另一种使用方法

    今天实习结束休息的时候无聊,于是便想看看机房有多少机器,IP是什么,有没有什么小漏洞. 依次使用了netstat.ping.Telnet以后,不小心输入了这样一个东西 当时按下回车以后,心里想的是这样 ...

  3. 好文章之——PHP系列(一)

    注:最近实习的公司是一家做电商企业,后台主要是php开发,好久不怎么接触php的我看了几篇相关文章,提高下对它的认识与理解,发现里面的学习思路还是非常好的,当然也会重新拾一下基础知识啦! 其实自己心中 ...

  4. java解析Json字符串之懒人大法

    面对Java解析Json字符串的需求,有很多开源工具供我们选择,如google的Gson.阿里巴巴的fastJson.在网上能找到大量的文章讲解这些工具的使用方法.我也是参考这些文章封装了自己的Jso ...

  5. gitlab搭建与配置说明

    1. 概述 Gitlab分为社区版和企业版,此次安装的是社区版(gitlab-ce). 2. 准备 本次使用系统为Ubuntu16.04. 3. 安装 添加GitLab仓库,并安装到服务器上(将git ...

  6. codeforces116B

    Little Pigs and Wolves CodeForces - 116B Once upon a time there were several little pigs and several ...

  7. easyui 功能介绍

    最近使用easyui, 下面,我介绍下常用功能: //绑定Product总类型 $('#gdv_ProductParentType').datagrid({ url: '../api/BindData ...

  8. TCP的三次握手与四次挥手过程,各个状态名称与含义

    三次握手 第一次握手:主机A发送位码为syn=1,随机产生seq number=10001的数据包到服务器,主机B由SYN=1知道,A要求建立联机,此时状态为SYN_SENT: 第二次握手:主机B收到 ...

  9. Luogu 4294 [WC2008]游览计划 | 斯坦纳树

    题目链接 Luogu 4294 (我做这道题的时候BZOJ全站的SPJ都炸了 提交秒WA 幸好有洛谷) 题解 这道题是[斯坦纳树]的经典例题.斯坦纳树是这样一类问题:带边权无向图上有几个(一般约10个 ...

  10. [luogu2280][bzoj1218][HNOI2003]激光炸弹

    题目描述 一种新型的激光炸弹,可以摧毁一个边长为R的正方形内的所有的目标.现在地图上有n(N<=10000)个目标,用整数Xi,Yi(其值在[0,5000])表示目标在地图上的位置,每个目标都有 ...