`

用python解一道奥数题(小学三年级)

阅读更多
今天在谢老师的blog上看到她小孩的一道奥数作业(难倒了N个硕士和博士的三年级奥数题),题目如下:

一个六位数,分别用2,3,4,5,6乘它,得到的五个新数仍是由原数中的六个数字组成,只是位置不同,则此六位数是多少?

顺手用python写了个解法:
python 代码
 
  1. def makeSet(num):  
  2.     tmp = set()  
  3.     for i in xrange(1,7):  
  4.         item = list(set(str(num*i)))  
  5.         item.sort()  
  6.         item = "".join(item)  
  7.         tmp.add(item)  
  8.     return tmp  
  9.   
  10. for i in xrange(100000,1000000):  
  11.     if len(makeSet(i))==1:  
  12.         print i  
  13.         break  
  14.   
  15. 输出结果为142857。  
分享到:
评论
17 楼 marshluca 2009-11-13  

def sort(x,i)
   return (x*i).to_s.split("").sort
end

for x in 100000...1000000
  tmp = sort(x,1)
  if sort(x,2)==tmp and sort(x,3)==tmp and sort(x,4)==tmp and sort(x,5)==tmp and sort(x,6)==tmp
    puts x
  end
end

16 楼 jamesqiu 2009-10-11  
写了个java的解:

void 小学奥数() {
L: for (int i = 111111; i < 1000000/6; i++) {
String si = set(i);
List<String> ss = Arrays.asList(set(i*2), set(i*3), set(i*4), set(i*5), set(i*6));
for (String s : ss) {
if (!s.equals(si)) continue L;
}
System.out.printf("i=%d (i*2=%d, i*3=%d, i*4=%d, i*5=%d, i*6=%d) \n", i, i*2, i*3, i*4, i*5, i*6);
   }
}

// 数n的所有数字的排序字符串
String set(int n) {
char[] ca = (""+n).toCharArray();
Arrays.sort(ca);
return new String(ca);
}
15 楼 chyichin 2008-12-29  
笨笨狗 写道

chyichin 写道
你好 我想请教你一个问题 我复制你的代码去运行 为什么报错呢? for i in xrange(100000,1000000):&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp; if len(makeSet(i))==1:&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; print i&amp;nbsp;&amp;nbsp; &amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; break SyntaxError: invalid syntax 错误指向 for变为粉红色的底 我是用Python Shell粘贴运行你的那代码 是这样吗? 或许是复制过去缩进乱了的问题,你可以用IDLE试试……

你好,IDLE 我复制了之后 回车就报错“SyntaxError: invalid syntax”
嗯 不会用这个工具
14 楼 笨笨狗 2008-12-25  
chyichin 写道

你好 我想请教你一个问题 我复制你的代码去运行 为什么报错呢? for i in xrange(100000,1000000):&nbsp;&nbsp; &nbsp;&nbsp;&nbsp; if len(makeSet(i))==1:&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; print i&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; break SyntaxError: invalid syntax 错误指向 for变为粉红色的底 我是用Python Shell粘贴运行你的那代码 是这样吗?



或许是复制过去缩进乱了的问题,你可以用IDLE试试……
13 楼 chyichin 2008-12-24  
你好 我想请教你一个问题
我复制你的代码去运行 为什么报错呢?
for i in xrange(100000,1000000):  
    if len(makeSet(i))==1:  
        print i  
        break
SyntaxError: invalid syntax
错误指向 for变为粉红色的底


我是用Python Shell粘贴运行你的那代码 是这样吗?
12 楼 chyichin 2008-12-24  
python看起来有点像vbs呵呵 刚学python听说速度很快
11 楼 meteoric_cry 2008-08-30  
 俺用JS写了一个,得到的结果与你一样。。。。
嘻嘻。。。。:) HOHO。。
不过我读你的题目就读了N久了,因为你“一个六位数,分别用2,3,4,5,6乘它,得到的五个新数仍是由原数中的六个数字组成”一个六位数乘以2,3,4,5,6怎么会得到五个新数呢,应该是说得到的六个数还是原来六个数组成滴!!!!!不多说了,看结果就知道了
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <HEAD>
  <TITLE> New Document </TITLE>
  <META NAME="Generator" CONTENT="EditPlus">
  <META NAME="Author" CONTENT="ZhangYi">
  <META NAME="Keywords" CONTENT="">
  <META NAME="Description" CONTENT="">
  <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
  <style type="text/css">
	
  </style>

  <script type="text/javascript">
	function isEqual(str1,str2) {
		var len1 = str1.length;
		var len2 = str2.length;
		//alert(typeof str1+"\n"+typeof str2)
		if(len1 != len2) return false;
		
		var temparr = str1.split("");
        var pos = -1;
	
		for (var i=0;i<len1;i++ )
		{	
			var rspos = str2.indexOf(temparr[i]);			
			if(rspos != -1) {
				if(pos != rspos) {
					pos = rspos;
					continue;
				}else {
					return false;
				}				
			} else {
				return false;
			}
		}
		return true;
	}

	function makeSet(num) {		
		var temp = num.toString();
		for (var i=2;i<7;i++)
		{
			var newNum = (i*num).toString();
			
			if(isEqual(temp,newNum)) {
				continue;
			}
			 else {
				return false;
			}
		}
		return true;
	}
	
	for (var i=100000;i<1000000 ;i++ )
	{
		if(makeSet(i)) {
			alert(i);
			break;
		}
	}
  </script>
 </HEAD>

 <BODY>
    
 </BODY>
</HTML>

10 楼 笨笨狗 2008-04-17  
引用
今天给tony看那个仿google导航图标的例子, 他一下子认出是你, 哈哈, 原来是校友啊!


呵呵,师哥好,俺是0111的呢,以后常联系哦,加你链接得了:)
9 楼 danielking 2008-04-16  
今天给tony看那个仿google导航图标的例子, 他一下子认出是你, 哈哈, 原来是校友啊!
8 楼 danielking 2008-04-16  
没人用人脑去解这个题吗?
7 楼 duka 2008-03-29  
算是小小及格了.hehe
c = []
num5 = 2,3,4,5,6
for x in xrange(100000,1000000):
    for i1 in num5:
        i2 = list(str(i1*x))
        i2.sort()
        c.append(i2)
    if c.count(c[0]) == len(num5):
        print x
        break
    c = []
6 楼 charka 2007-09-07  
(5)中有一行错了,应该是:p*3=?w =>(p,w)=(7,1)|(4,2)|(8,4)|(5,5)
这个给三年级的学生讲明白也不太容易,有没有更简单的解法?
5 楼 charka 2007-09-07  
昨晚没睡好,用呓语言得到的解法
设 x=abcdef;
(1)
   6x是六位数 => a=1
(2)
   x*[1,2,3,4,5,6]得到的六位数由abcdef组成
   =>f*[1,2,3,4,5,6]=[a,b,c,d,e,f];a=1
   =>f*3=?1
   =>f=7
(3)
   x=1bcde7
   7*[1,2,3,4,5,6]的个位=[7,4,1,8,5,2]=[a,b,c,d,e,f]
(4)
   3x=????u1; 6x=????v2=>(u,v)=(2,4)|(4,8)|(7,4)
   u=2;e7*3=?u1=>e*3=?0,与(3)矛盾
   u=4; e7*3=?u1 =>e*3=?2 =>e=4 => x=1bcd47;2x=????94 => e!=4
   u=7; e7*3=?u1 => e*3=?5 =>e=5
   ==>>e=5
(5)
x=1bcd57 =>
    2x=???p14=> p!=[1,4]
    4x=???q28 => q!=[2,8]
    6x=???w42 => w!=[4,2]
    p*2=?q => (p,q) =(2,4)|(4,8)|(7,4)
    p*3=?w =>(p,q)=(7,1)|(4,2)|(8,4)|(5,5)
==>p=7 =>d*2+1=?7 =>d=8
(6) x=1bc857
   b=2;c=4 => 2x=249714 矛盾
==> b=4,c=2
(7)
    x=142857
4 楼 ms99ster 2007-07-12  
谢老师的blog上还有另外的一道奥数题

“足球*篮球=踢足球1”,在上面的乘法算式中,不同的汉字代表不同的数学,相同的汉字代表相同的数学。其中,乘积是一个个位为1的四位数,那么“足球”和“篮球”这两个两位数的和是多少?

结果好像是69*39=2691
用手算出来的,也没有看懂上面的程序
3 楼 Lich_Ray 2007-07-12  
程序已经彻底没意义了。这个问题我已经用数学方法证明出来了。
2 楼 笨笨狗 2007-07-12  
to Lich_Ray:

的确,最近看ruby,python的range给搞混淆了,而且,现在的版本用xrange更有效率,已经改过了。哈哈……
我对FP不是很熟悉,不过看样子很强大,但是这种问题,用常规的写法貌似普通人理解起来要容易得多。
1 楼 Lich_Ray 2007-07-11  
我也写了一个。本来想写成一句话的,后来发现用 Python 玩儿 FP 简直是受罪!Scheme 中的一句话被迫变成了这么多:
def list_equ (ls):
	for cond in map(lambda x: ls[0] == x, ls):
		if not cond:
			return False
	return True

def sort (ls):
	ls.sort()
	return ls

def test_num (num):
	return list_equ(map(lambda x: reduce(lambda i,j: i+j, sort(list(str(x * num)))), range(2,7)))

# 这招只能在 Haskell 中用
#def give_rst ():
#	return filter(test_num, range(100000,1000000))
	
# 今天太生气了,干脆用这个了:
 for i in range(100000,1000000):
     if (test_num(i)):
             print i
             break

PS: 楼上对于 range() 函数边界的理解有误。range(1,6) 的结果是 [1,2,3,4,5] 而不是 [2,3,4,5,6]。应该用 range(2,7),虽然结果不变。

相关推荐

    中小学数学题程序_instance62k_python题_Python解数学题_Python解奥数题_python解初中题_

    在Python编程领域,解决中小学数学题,包括奥数题和初中数学题,是一种常见的实践,旨在提高编程技能和逻辑思维能力。"instance62k_python题"可能指的是一个包含62000个数学问题的实例集合,这些题目涵盖了从小学到...

    用python编写的一些奥数题.pdf

    以下是一些使用Python编写的典型奥数题及其解决方案: 1. **计算连续整数之和**: 这个例子展示了如何计算1到113的所有数字之和。使用`for`循环遍历1到113的整数,将每个数字累加到变量`sum`中。最后,打印出总和...

    python计算机二级题库(附带答案)

    python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python计算机二级题库(附带答案)python...

    python 破解 wifi密码

    python 实现wifi密码的暴力破解。

    第01课-初识Python-小学五年级兴趣课

    到了2018年,根据TIOBE编程语言排行榜,Python在全球编程语言中排名第三。 计算机与程序设计: 计算机是根据指令操作数据的设备,它具有可编程性,可以根据预设的程序来处理数据。程序设计(编程)则是设计、编制、...

    Python编程练习题60题-含答案

    该资源共包含 10 道 Python 编程练习题,涵盖了 Python 基础知识点,包括编程备注、日期时间处理、列表遍历、条件语句、循环语句、列表切片、字典处理等。 1. Python 编程备注 在 Python 中添加备注可以使用 # ...

    Python面试选择题题库

    自己整理一些大厂的面试题题库,都是一些常见的题目,希望能给大家提供帮助,题库分为3个部分这是第二部分

    小学数学口算题是一款利用Python开发了一套自动生成小学生口算题的小应用.rar

    孩子上小学一年级了,加减乘除的口算就要开始练习了,估计老师肯定会让家长出题,所以提前准备一下,利用Python开发了一套自动生成小学生口算题的小应用。而且今天是程序员节,撸200行代码庆祝一下。:) 程序核心...

    150道python练习题.rar

    内容参考博客 值得收藏的100道Python经典练手题及详细答案,建议认真练习! 150道python练习题 内容参考博客 值得收藏的100道Python经典练手题及详细答案,建议认真练习! 150道python练习题 内容参考博客 值得...

    2022年NOC软件创意编程(学而思赛道)选拔赛小学高年级组python,包含答案详细解析.pdf

    【2022年NOC软件创意编程(学而思赛道)选拔赛小学高年级组Python】是一项旨在激发小学生对编程兴趣和创新能力的比赛。比赛涵盖了Python编程的基础知识和应用技能,旨在培养学生的逻辑思维和问题解决能力。在这个...

    Python 海龟绘图 120 题

    Python 海龟绘图 120 题 ...Python 海龟绘图 120 题涵盖了 turtle 基本命令、绘制基本图形、循环命令、综合应用、turtle 对象的使用等方面的知识点,为学习 Python 海龟绘图提供了prehensive 指南。

    第14届蓝桥杯Python省赛真题-大学B组

    第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛真题-大学B组 第14届蓝桥杯Python省赛...

    Python期末考试题 Python程序设计考试题 Python编程期末测评题目 共22页

    Python期末考试题通常会涵盖多个方面,旨在测试学生对Python编程基础的掌握程度,包括语法、数据结构、控制流、函数、错误处理等核心概念。 一、选择题: 1. 表达式`'%d%%%d' %(3 / 4, 3 % 4)`的值是判断浮点数与...

    NOC-python能力选拔模拟题附答案

    ### NOC-Python能力选拔模拟题知识点解析 #### 一、单选题知识点解析 **1、关于"+"号的使用** - **知识点**: `+`符号的用途与区别。 - 在字符串中作为拼接的功能。 - 在数值类型中作为数学加法运算。 - 字符串...

    第14届蓝桥杯Python省赛真题-大学C组

    第14届蓝桥杯Python省赛真题-大学C组 第14届蓝桥杯Python省赛真题-大学C组 第14届蓝桥杯Python省赛真题-大学C组 第14届蓝桥杯Python省赛真题-大学C组 第14届蓝桥杯Python省赛真题-大学C组 第14届蓝桥杯Python省赛...

    python解二元二次方程代码.docx

    在本文中,我们将探讨如何使用Python来解决二元二次方程。二元二次方程通常形式为ax² + by² + cxy + dx + ey + f = 0,其中a, b, c, d, e, f是常数,且a, b, c不全为零。解决这类方程需要应用数学知识,如代数和根...

    Python训练100题_Python基础训练100题_

    "Python训练100题"是一份专为新手设计的资源,旨在帮助学习者巩固和提升Python编程基础。这100道题目覆盖了Python语言的核心概念,包括语法、数据类型、控制结构、函数、模块、错误与异常处理等多个方面。 1. **...

    电子学会Pythonk考级三级历年真题

    《电子学会Pythonk考级三级历年真题》是中国电子学会为全国青少年软件编程能力提升而设立的一项重要考试,旨在培养青少年的Python编程技能。自2020年9月起,该考试已连续举办多次,每年都会更新题库,以适应编程教育...

    python中级试题(含答案)_python选择题及答案

    python中级试题(含答案)

Global site tag (gtag.js) - Google Analytics