免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: ssfjhh
打印 上一主题 下一主题

[C] python版的问题,python版太冷清了,我给转到C版来,等高手的精彩回复 [复制链接]

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
11 [报告]
发表于 2013-03-18 10:48 |只看该作者
回复 10# ssfjhh
算法应该是对的。
设两蚁相遇,则交换灵魂,而肉体掉头行驶。
以 3 -7 11 -17 23 为例,
第一个负数为-7,则说明-7的灵魂在左边第一个掉下去,耗时7秒。而承载起灵魂的肉体一定是左边第一个数3
第二个负数为-17,则说明-17的灵魂在左边第二个掉下去,耗时17秒。而承载起灵魂的肉体一定是左边第二个数-7
右边亦复如是

我把你python代码改为C++代码^_^(这才是我主要目的)
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;

  5. void ant( int m, std::initializer_list<int> k )
  6. {
  7.     // python: p = sorted(args, key = abs)
  8.     vector<int> v1( k );
  9.     sort( v1.begin(), v1.end(), [](int a, int b){ return abs(a)<abs(b); } );

  10.     // python: t = [i for i in p if i<0] + [ for i in p if i >0]
  11.     vector<int> v2( k );
  12.     sort( v2.begin(), v2.end(), [](int a, int b){ return a<0&&b<0 ? a>b : a<b; } );

  13.     // python: zip(-t或m-t,p)
  14.     vector<pair<int,int>> v3;
  15.     for( size_t i=0; i!=k.size(); ++i )
  16.         v3.push_back( make_pair(v2[i]>0?m-v2[i]:0-v2[i], v1[i]) );
  17.     // python: sorted zip
  18.     sort( v3.begin(), v3.end(), [](pair<int,int> a, pair<int,int> b){ return a.first<b.first; } );

  19.     // python: print
  20.     for( auto v : v3 )
  21.         cout << " (" << v.first << ',' << v.second << ')';
  22.     cout << endl;
  23. }

  24. int main()
  25. {
  26.     ant( 27, {3,-7,11,-17,23} );

  27.     return 0;
  28. }
复制代码

论坛徽章:
4
金牛座
日期:2013-10-11 16:12:50卯兔
日期:2014-07-31 09:17:19辰龙
日期:2014-08-08 09:28:02狮子座
日期:2014-09-14 20:32:05
12 [报告]
发表于 2013-03-19 08:52 |只看该作者
回复 11# bruceteen


   
算法应该是对的。
设两蚁相遇,则交换灵魂,而肉体掉头行驶。
以 3 -7 11 -17 23 为例,
第一个负数为-7,则说明-7的灵魂在左边第一个掉下去,耗时7秒。而承载起灵魂的肉体一定是左边第一个数3
第二个负数为-17,则说明-17的灵魂在左边第二个掉下去,耗时17秒。而承载起灵魂的肉体一定是左边第二个数-7
右边亦复如是


我一直喜欢跟学计算机的人打交道,因为我觉得大多数学计算机的逻辑思路非常清晰,表达问题也非常简洁明了,上面这个描述就是个例子,我想出这个算法,但是想记下来备忘,却总感觉叙述啰嗦不堪,表面的也不够明白,总感觉以后我自己也看不明白,这个描述甚好,我要给转走了。当作我的代码注释。
freshxman 该用户已被删除
13 [报告]
发表于 2013-03-19 09:16 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
4
金牛座
日期:2013-10-11 16:12:50卯兔
日期:2014-07-31 09:17:19辰龙
日期:2014-08-08 09:28:02狮子座
日期:2014-09-14 20:32:05
14 [报告]
发表于 2013-03-19 09:19 |只看该作者
freshxman 发表于 2013-03-19 09:16
这就是所谓的穿越阿



嘛意思呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP