【编程学习】数组转矩阵

一、题目:

给定一个一维数组,要求是将数组转化成一个矩阵。数组的输入作为矩阵的第一列,之后每一列的数值,都要比上一列下移一行。

举例

输入:

[1,2,3,4,5,6,7,8,9,10]

输出:

1 10 9 8 7 6 5 4 3 2
2 1 10 9 8 7 6 5 4 3
3 2 1 10 9 8 7 6 5 4
4 3 2 1 10 9 8 7 6 5
5 4 3 2 1 10 9 8 7 6
6 5 4 3 2 1 10 9 8 7
7 6 5 4 3 2 1 10 9 8
8 7 6 5 4 3 2 1 10 9
9 8 7 6 5 4 3 2 1 10
10 9 8 7 6 5 4 3 2 1

二、解题

解题思路:动态规划

从题目和举例看,第一列,就是输入的数组值竖排,那么:

从第二列开始,取值相比第一列,相当于一个环,往下转动了一行,然后赋值,在dp上,应该是:

示例代码:Go

func ConvertToMatrix(input []int32) (error, [][]int32) {
	dataLen := int32(len(input))
	if (input == nil) || (dataLen == 0) {
		return errors.New("invalid Input"), nil
	}

	dp := make([][]int32, dataLen)
	for i := range dp {
		dp[i] = make([]int32, dataLen)
	}

	for i := int32(0); i < dataLen; i++ {
		dp[i][0] = input[i]
	}

	for j := int32(1); j < dataLen; j++ {
		dp[0][j] = dp[dataLen-1][j-1]
		for i := int32(1); i < dataLen; i++ {
			dp[i][j] = dp[i-1][j-1]
		}
	}

	return nil, dp
}
相关推荐
huapiaoy7 分钟前
Redis中数据类型的使用(hash和list)
redis·算法·哈希算法
冷白白20 分钟前
【C++】C++对象初探及友元
c语言·开发语言·c++·算法
z樾22 分钟前
Github界面学习
学习
鹤上听雷28 分钟前
【AGC005D】~K Perm Counting(计数抽象成图)
算法
一叶祇秋40 分钟前
Leetcode - 周赛417
算法·leetcode·职场和发展
小吴同学(wlx)42 分钟前
Golang 进阶3—— 协程&管道
golang
技术卷42 分钟前
GO网络编程(三):海量用户通信系统1:登录功能初步
golang·网络编程
武昌库里写JAVA1 小时前
【Java】Java面试题笔试
c语言·开发语言·数据结构·算法·二维数组
ya888g1 小时前
GESP C++四级样题卷
java·c++·算法
道爷我悟了1 小时前
Vue入门-指令学习-v-html
vue.js·学习·html