Fortran Coder

查看: 11984|回复: 10
打印 上一主题 下一主题

[通用算法] 求多个数组元素的排列的思路

[复制链接]

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
跳转到指定楼层
楼主
发表于 2017-5-24 09:38:02 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
有n个数组,每个数组里拿出一个元素进行排列,无需组合,但因为n很大,所以不想用循环,想请问各位大神有没有高效一点的编程的思路
分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

835

帖子

2

主题

0

精华

大宗师

F 币
3926 元
贡献
2334 点
沙发
发表于 2017-5-24 10:29:28 | 只看该作者
没看懂你的意图。

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
板凳
 楼主| 发表于 2017-5-24 15:17:56 | 只看该作者
例如有a,b,c,d四个数组,从a中拿出一个元素去乘b中的一个元素,再去乘上c,d中各一个元素,最后要求a,b,c,d中每一个元素都进行这样的运算,求出所有的排列方式

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
地板
 楼主| 发表于 2017-5-24 15:18:14 | 只看该作者
li913 发表于 2017-5-24 10:29
没看懂你的意图。


例如有a,b,c,d四个数组,从a中拿出一个元素去乘b中的一个元素,再去乘上c,d中各一个元素,最后要求a,b,c,d中每一个元素都进行这样的运算,求出所有的排列方式

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1641 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

5#
发表于 2017-5-24 16:00:26 | 只看该作者
循环是一种很基本的语法。如果你不想写,那就只好
write(*,*) a(1) * b(1)
write(*,*) a(1) * b(2)
write(*,*) a(1) * b(3)
write(*,*) a(1) * b(4)
....
write(*,*) a(2) * b(1)
write(*,*) a(2) * b(2)
write(*,*) a(2) * b(3)
write(*,*) a(2) * b(4)

这样了。

你这样的要求很过分。就好像,我想写一部红楼梦,但是我不想写感叹词。

835

帖子

2

主题

0

精华

大宗师

F 币
3926 元
贡献
2334 点
6#
发表于 2017-5-24 16:31:17 | 只看该作者
本帖最后由 li913 于 2017-5-24 16:39 编辑

我认为循环是比较高效的形式。是否N较大,循环层数太多?如果N真的非常大(比如十万),每个数组中各有十万个数据,这种情况的确得用其他方法,但执行效率肯定低一些。

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
7#
 楼主| 发表于 2017-5-24 16:37:25 | 只看该作者
fcode 发表于 2017-5-24 16:00
循环是一种很基本的语法。如果你不想写,那就只好
write(*,*) a(1) * b(1)
write(*,*) a(1) * b(2)

谢谢你的指导,我明白了

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
8#
 楼主| 发表于 2017-5-24 16:37:44 | 只看该作者
li913 发表于 2017-5-24 16:31
我认为循环是比较高效的形式。你是否认为N较大,循环层数多,不想写代码?如果N真的非常大,比如十万,那的 ...

感谢你的回复

28

帖子

8

主题

0

精华

熟手

F 币
144 元
贡献
85 点
9#
 楼主| 发表于 2017-5-30 15:50:54 | 只看该作者
li913 发表于 2017-5-24 16:31
我认为循环是比较高效的形式。是否N较大,循环层数太多?如果N真的非常大(比如十万),每个数组中各有十万 ...

对,n很大,每组数据比较多,循环比较麻烦,请问有没有别的方法?

490

帖子

4

主题

0

精华

大宗师

F 币
3298 元
贡献
1948 点

水王勋章元老勋章热心勋章

10#
发表于 2017-5-30 20:47:34 | 只看该作者
本帖最后由 pasuka 于 2017-5-30 20:49 编辑

为啥不能先对数据预处理进行降维呢?
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-12-25 01:09

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表