【Go语言入门100题】050 倒数第N个字符串 (15 分) Go语言|Golang

简介: L1-050 倒数第N个字符串 (15 分) Go语言|Golang给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, …, aaz, aba, abb, …, abz, …, zzz }。这个序列的倒数第27个字符串就是 zyz。对于任意给定的 L,本题要求你给出对应序列倒数第 N 个字符串。

L1-050 倒数第N个字符串 (15 分) Go语言|Golang

给定一个完全由小写英文字母组成的字符串等差递增序列,该序列中的每个字符串的长度固定为 L,从 L 个 a 开始,以 1 为步长递增。例如当 L 为 3 时,序列为 { aaa, aab, aac, …, aaz, aba, abb, …, abz, …, zzz }。这个序列的倒数第27个字符串就是 zyz。对于任意给定的 L,本题要求你给出对应序列倒数第 N 个字符串。


输入格式:

输入在一行中给出两个正整数 L(2 ≤ L ≤ 6)和 N(≤10


输出格式:

在一行中输出对应序列倒数第 N 个字符串。题目保证这个字符串是存在的。


输入样例1:

3 7417


结尾无空行


输出样例1:

pat


结尾无空行


思路:

这题看上去很唬人,其实只是一个26进值的转化而已。

首先知道总数是多少,才能对各个进行位置进行求余操作。

代码如下:

package main
import (
  "fmt"
  "math"
)
func main() {
  var L,N int
  _,_ = fmt.Scan(&L,&N)
  a:= make([]rune,7)
  sum := math.Pow(26,float64(L))  //求出总数
  tmp := int(sum)-N  // 然后计算出一共要多少位,因为是倒数第N位,减去就是这个了正数第几位了
  // 然后用这个数对26不断求余,除整就够了。
  for i := L - 1; i >= 0; i-- {
    a[i] = 'a'+ rune(tmp%26)  
    tmp /= 26
  }
  for i := 0; i < L; i++ {
    fmt.Printf("%s",string(a[i]))
  }
}
相关文章
|
14天前
|
Go
Go字节数组与字符串相互转换
Go字节数组与字符串相互转换
28 3
|
12天前
|
存储 Go
go语言字符串变小写
go语言字符串变小写
|
2月前
|
Go 开发者
|
2月前
|
测试技术 Go 开发者
掌握Golang测试:从入门到实践
【8月更文挑战第31天】
35 0
|
2月前
|
JSON Go 数据格式
Go实现json字符串与各类struct相互转换
文章通过Go语言示例代码详细演示了如何实现JSON字符串与各类struct之间的相互转换,包括结构体对象生成JSON字符串和JSON字符串映射到struct对象的过程。
16 0
|
2月前
|
Unix Go
Go从入门到放弃之时间操作
Go从入门到放弃之时间操作
|
2月前
|
机器学习/深度学习 移动开发 Linux
Go从入门到放弃之文件操作
Go从入门到放弃之文件操作
|
1月前
|
Go
Golang语言之管道channel快速入门篇
这篇文章是关于Go语言中管道(channel)的快速入门教程,涵盖了管道的基本使用、有缓冲和无缓冲管道的区别、管道的关闭、遍历、协程和管道的协同工作、单向通道的使用以及select多路复用的详细案例和解释。
55 4
Golang语言之管道channel快速入门篇
|
1月前
|
Go
Golang语言文件操作快速入门篇
这篇文章是关于Go语言文件操作快速入门的教程,涵盖了文件的读取、写入、复制操作以及使用标准库中的ioutil、bufio、os等包进行文件操作的详细案例。
49 4
Golang语言文件操作快速入门篇
|
1月前
|
Go
Golang语言之gRPC程序设计示例
这篇文章是关于Golang语言使用gRPC进行程序设计的详细教程,涵盖了RPC协议的介绍、gRPC环境的搭建、Protocol Buffers的使用、gRPC服务的编写和通信示例。
58 3
Golang语言之gRPC程序设计示例