题目地址:http://club.excelhome.net/thread-175411-1-1.html
先看几个数:312132,231213,41312432,23421314
可以看到以上字串有以下特点: 2个1 之间有1个数,2个2 之间有2个数,2个3之间有3个数...
试找出由(1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8) 16个数组成的字符串满足上述条件的所有组合,即2个1 之间有1个数,2个2 之间有2个数,2个3之间有3个数...2个8之间有8个数.
1,1,2,2,3,3,...N,N共2N个数排成一行,2个1 之间有1个数,2个2 之间有2个数,...2个N之间有N个数...
设 1 放在A(1) ,A(1) + 2
2 放在A(2) ,A(2) + 3
3 放在A(3) ,A(3) + 4
....
N 放在A(N) ,A(N)+N+1
则A(1), A(1)+2, A(2), A(2)+3,...,A(N) + N + 1 为1,2,3,4,..2N的一个全排列
故 1 + 2 + 3 + ... + 2N = 2[A(1) + A(2) + ... + A(N)] + [2 + 3 + ... + (N+1)]
2N(2N+1)/2 = 2[A(1) + A(2) + ... + A(N)] + (N+1)(N+2)/2 - 1
4[A(1) + A(2) + ... + A(N)] = 2N(2N+1) - (N+1)(N+2) + 2
A(1) + A(2) + ... + A(N) = N(3N-1)/4
所以 N 只能是 4K,4K+3 的形式.
N=1,2,5,6,9时无解
N=3: 312132,231213
N=4: 41312432,23421314
N=7; 52个解
N=8: 300个解
方法1(提供)
-
PrivateMaxAsLong,mycountAsLong
-
PrivateSubCommand1_Click()
-
DimW()
-
DimNum(1To8)AsBoolean
-
DimpAsLong
-
DimFillLeftAsLong
-
ForMax=6To16Step2
-
ReDimW(1ToMax)
- FillLeft=Max/2
- p=1
-
CallBody(W,Num,p,FillLeft)
-
EraseW
-
Next
-
EndSub
-
PrivateSubBody(ByRefW(),ByRefNum()AsBoolean,_
-
ByRefpAsLong,ByRefFillLeftAsLong)
-
DimtAsLong
-
-
CallMoveP(W,p)
-
- t=Max-p-1
-
Ift>8Thent=8
-
Do
-
- t=GetMaxUnuse(Num,t)
-
Ift>0Then
-
-
IfBeTwins(Num,W,t,p)=TrueThen
- FillLeft=FillLeft-1
-
IfFillLeft=0Then
-
-
IfUBound(W)=16Then
- mycount=mycount+1
-
CallShowResult(W)
-
EndIf
-
Else
-
-
CallBody(W,Num,p,FillLeft)
-
EndIf
-
-
DoWhileBackTwins(Num,W,p)=False
- p=p-1
-
Loop
- FillLeft=FillLeft+1
-
EndIf
- t=t-1
-
EndIf
-
LoopUntilt=0
-
EndSub
-
PrivateSubMoveP(ByRefW(),ByRefpAsLong)
-
DoWhileW(p)>0
- p=p+1
-
Loop
-
EndSub
-
PrivateFunctionGetMaxUnuse(ByRefNum()AsBoolean,ByValMaxNumAsLong)AsLong
-
DimtAsLong
-
Fort=MaxNumTo1Step-1
-
IfNum(t)=FalseThen
- GetMaxUnuse=t
-
ExitFor
-
EndIf
-
Next
-
EndFunction
-
PrivateFunctionBeTwins(ByRefNum()AsBoolean,ByRefW(),_
-
ByValNumberAsLong,ByValpAsLong)AsBoolean
-
DimpMirAsLong
-
BeTwins=False
-
-
IfNum(Number)=TrueThenExitFunction
-
-
IfW(p)>0ThenExitFunction
-
- pMir=p+Number+1
-
-
IfpMir>MaxThenExitFunction
-
-
IfW(pMir)>0ThenExitFunction
-
-
Num(Number)=True
- W(p)=Number
- W(pMir)=Number
-
BeTwins=True
-
EndFunction
-
PrivateFunctionBackTwins(ByRefNum()AsBoolean,ByRefW(),_
-
ByValpAsLong)AsBoolean
-
DimpMirAsLong
-
BackTwins=False
-
-
IfW(p)=0ThenExitFunction
-
- pMir=p+W(p)+1
-
-
IfpMir>MaxThenExitFunction
-
-
IfW(pMir)=0ThenExitFunction
-
IfW(pMir)<>W(p)ThenExitFunction
-
-
Num(W(p))=False
- W(p)=0
- W(pMir)=0
-
BackTwins=True
-
EndFunction
-
PrivateSubShowResult(ByRefW())
-
Debug.Printmycount&vbTab&Join(W,"")
-
EndSub
n=7 时,有52个解:
1 74151643752362
2 73625324765141
3 73161345726425
4 72632453764151
5 72462354736151
6 72452634753161
7 71416354732652
8 71316435724625
9 62742356437151
10 61517346532472
11 57416154372632
12 57263254376141
13 57236253471614
14 57141653472362
15 56171354632742
16 53672352461714
17 53647352462171
18 52732653417164
19 52642753461317
20 52472654131763
21 52462754316137
22 51716254237643
23 46357432652171
24 46171452632753
25 46171435623725
26 45671415362732
27 41716425327635
28 41617435263275
29 37463254276151
30 36713145627425
31 35743625427161
32 35723625417164
33 34673245261715
34 34573641512762
35 27423564371516
36 26721514637543
37 26327435614175
38 26325734615147
39 25623745361417
40 24723645317165
41 23726351417654
42 23627345161475
43 17126425374635
44 17125623475364
45 16172452634753
46 16135743625427
47 15173465324726
48 15167245236473
49 15163745326427
50 15146735423627
51 14167345236275
52 14156742352637
n=8 时,有300个解:
1 8642752468357131
2 8642572468531713
3 8631713568427524
4 8613175368425724
5 8527326538471614
6 8514167548236273
7 8457264258376131
8 8456274258631713
9 8451714658237263
10 8427524638573161
11 8426724358637151
12 8416174358632752
13 8372632458764151
14 8357236258471614
15 8352732658417164
16 8316135748625427
17 8273264358746151
18 8271216458734653
19 8271215648735463
20 8253267358416174
21 8247263458376151
22 8246257438653171
23 8237243568471516
24 8236253748651417
25 8141673458362752
26 8131743568427526
27 8131573468524726
28 8131563748526427
29 8121726358437654
30 8121724568347536
31 8121627538463574
32 8121625748365437
33 7831613574862542
34 7823625374865141
35 7813156374852642
36 7812162574836543
37 7582462574386131
38 7581416574382632
39 7562842576431813
40 7561814576342832
41 7536483574612182
42 7528623574368141
43 7518136573428624
44 7516184573642382
45 7485264275386131
46 7481514673582362
47 7468254276358131
48 7463584376512182
49 7426824375631815
50 7425824675131863
51 7416184572632583
52 7386235274685141
53 7386131574682542
54 7385236275481614
55 7368131576428524
56 7345638475261218
57 7318134675248265
58 7283246375481615
59 7281216475384635
60 7281215673485364
61 7263285376415184
62 7246258473651318
63 7245286475131683
64 7245268475316138
65 7238243675418165
66 7236283475614185
67 7141863475326825
68 7141586472532683
69 7141568473526328
70 7131853672452864
71 7131683572462584
72 7131683475264285
73 6852472654831713
74 6831713645827425
75 6827325634875141
76 6814157643852372
77 6752842657431813
78 6751814657342832
79 6734583647512182
80 6714185647235283
81 6485724625387131
82 6475824625731813
83 6475384635712182
84 6471814652732853
85 6471814635723825
86 6418174625328735
87 6417184635273285
88 6384537642582171
89 6378131645728425
90 6357832652471814
91 6357438654271218
92 6285247635483171
93 6284273645381715
94 6278234653748151
95 6275284635743181
96 6274258643751318
97 6258237653418174
98 6257248653471318
99 6238273651418754
100 6237283645171485
101 6181537643582472
102 6181473654382752
103 6171834653742852
104 6171825624735843
105 6151847652432873
106 6151748653427328
107 5864275246831713
108 5841715463827326
109 5827425634873161
110 5824625743861317
111 5823725364817146
112 5817135643872462
113 5814175642832763
114 5814165743826327
115 5784265247386131
116 5748625427368131
117 5746825427631813
118 5746385437612182
119 5728325637418164
120 5724825647131863
121 5716185347632482
122 5673485364712182
123 5671815364732842
124 5628425764318137
125 5618175264238743
126 5618145763428327
127 5378435624728161
128 5378235264718146
129 5374835641712862
130 5364835746121827
131 5286235743681417
132 5283275364181746
133 5248275461318736
134 5247285463171386
135 5181725623487364
136 5181375632482764
137 5181365734286247
138 5171835463724826
139 5161845736423827
140 5161785246237483
141 4862742356837151
142 4857141653872362
143 4853647352862171
144 4852642753861317
145 4835743625827161
146 4815146735823627
147 4782542637583161
148 4758141657238263
149 4753648357261218
150 4752842657131863
151 4738643257268151
152 4738543627528161
153 4718146257238653
154 4718143567328526
155 4716148537623528
156 4683547362582171
157 4682542763581317
158 4672842365731815
159 4637843265271815
160 4635843765121827
161 4618147365238275
162 4617148562372538
163 4586347532682171
164 4578141563728326
165 4567841516372832
166 4567348536271218
167 4278246151738653
168 4275248635713168
169 4268247516138573
170 4268243756318157
171 4258246751318637
172 4257248653171368
173 4181742562387536
174 4161845726325837
175 4161748526327538
176 4161748356237258
177 3862352746851417
178 3861315746825427
179 3857316154872642
180 3852362754816147
181 3847362452876151
182 3847326425871615
183 3845367425826171
184 3825327465814176
185 3782342567481516
186 3758316157428624
187 3746385427625181
188 3726328457614158
189 3681317562482574
190 3681317465284275
191 3681315764285247
192 3672382465714185
193 3645378465121728
194 3628327561418574
195 3627328564171548
196 3586371514682742
197 3582372564181746
198 3574386541712682
199 3568371516428724
200 3568347526428171
201 3568327526418174
202 3564378546121728
203 3486374151682752
204 3485374615182762
205 3485374265281716
206 3478324625718165
207 3467384516172582
208 3456384752612187
209 3181375264285746
210 3181367245286475
211 3181347562482576
212 3181346752482657
213 3171386425724685
214 3171384562742586
215 3171368524726548
216 3171358642752468
217 2862357436854171
218 2862171456834753
219 2852734653847161
220 2852716154837643
221 2852637453864171
222 2852467354836171
223 2842367435816175
224 2832463754816157
225 2812175364835746
226 2812174635843765
227 2812167345836475
228 2812164753846357
229 2812157463854376
230 2812156734853647
231 2782345637485161
232 2752683457364181
233 2742853467351816
234 2732583467514186
235 2682537463584171
236 2682171465384735
237 2672815164735843
238 2672485364735181
239 2642783465317185
240 2632853764151847
241 2632783561417584
242 2582473564381716
243 2572861514736843
244 2572834563741816
245 2572638543761418
246 2572368534716148
247 2482374635181765
248 2472864151736853
249 2462784516137583
250 2462584736513187
251 2452864751316837
252 2452684753161387
253 2382736151487654
254 2382437564181576
255 2382436754181657
256 2362834756141857
257 1815374635842762
258 1815267245836473
259 1814637543862572
260 1813475364825726
261 1718246257438653
262 1716384537642582
263 1716285247635483
264 1714853647352862
265 1714683547362582
266 1714586347532682
267 1713845367425826
268 1713568347526428
269 1712862357436854
270 1712852637453864
271 1712852467354836
272 1712682537463584
273 1618274265348735
274 1618257263458374
275 1617483564372582
276 1617285263475384
277 1615847365432872
278 1613857362452874
279 1613784365247285
280 1613758364257248
281 1518627523468374
282 1518473564328726
283 1517386532472684
284 1517368534276248
285 1516782542637483
286 1516738543627428
287 1516478534623728
288 1514678542362738
289 1418634753268257
290 1415864725326837
291 1415784365237286
292 1415684735263287
293 1318637245268475
294 1318536724528647
295 1317835264275846
296 1317538642572468
297 1316837425624875
298 1316835724625847
299 1316834752642857
300 1316738524627548
方法2(提供)
-
Dima(1To16),j,s
-
Subcai()
-
Forj=1To8
- s=0
- czj
-
Nextj
-
EndSub
-
Subcz(zz)
-
Fori=zz+2To2*j
-
Ifa(i)=0Anda(i-zz-1)=0Then
- a(i)=zz
- a(i-zz-1)=zz
-
Ifzz>1Then
- czzz-1
-
Else
-
Fork=1To2*j
- ls=ls&a(k)
-
Nextk
- s=s+1
-
Debug.Print"'"&ls
-
EndIf
- a(i)=0
- a(i-zz-1)=0
-
EndIf
-
Next
-
EndSub
C++ 代码(zhc6211026 提供)
-
#include<iostream>
-
usingnamespacestd;
-
int*numarr;
-
bool*numused;
-
voidDoubleN(intn,inti,intc=0);
-
voidprintnum(int*arr,intn);
-
intmain()
- {
-
intn,i;
- cin>>n;
-
numarr=newint[2*n];
-
numused=newbool[2*n];
-
for(i=0;i<2*n;i++)
- {
- numarr[i]=0;
-
numused[i]=false;
- }
- DoubleN(n,1);
-
return0;
- }
-
voidDoubleN(intn,inti,intc)
- {
-
intk=0;
-
for(k=0;k<2*n-i;k++)
- {
-
if(!numused[k]&&!numused[k+i+1])
- {
-
numused[k]=numused[k+i+1]=true;
- numarr[k]=numarr[k+i+1]=i;
-
if(i==n)
- {
- printnum(numarr,n);
- }
-
else
- {
- DoubleN(n,i+1);
- }
-
numused[k]=numused[k+i+1]=false;
- numarr[k]=numarr[k+i+1]=0;
- }
- }
- }
-
voidprintnum(int*arr,intn)
- {
-
for(inti=0;i<2*n;i++)
- {
- cout<<arr[i];
- }
- cout<<endl;
- }
还提供了将1,2,3,...N共3N个数排成一行,3个1 之间各有1个数,3个2 之间各有2个数,...3个N之间各有N个数...的递归方法
-
Dima(1To27),j,s
-
Subcai()
-
Forj=1To9
- s=0
- czj
-
Nextj
-
EndSub
-
Subcz(zz)
-
Fori=2*(zz+1)+1To3*j
-
Ifa(i)=0Anda(i-zz-1)=0Anda(i-2*(zz+1))=0Then
- a(i)=zz
- a(i-zz-1)=zz
- a(i-2*(zz+1))=zz
-
Ifzz>1Then
- czzz-1
-
Else
-
Fork=1To3*j
- ls=ls&a(k)
-
Nextk
- s=s+1
-
Cells(s,j*2)="'"&ls
-
EndIf
- a(i)=0
- a(i-zz-1)=0
- a(i-2*(zz+1))=0
-
EndIf
-
Nexti
-
EndSub
代码返回:
191618257269258476354938743 |
191218246279458634753968357 |
181915267285296475384639743 |
347936483574692582762519181 |
753869357436854972642812191 |
347839453674852962752816191 |
分享到:
相关推荐
此外,卖马问题不仅是一道算术题,还融入了等比数列的知识,需要学生通过数学运算来求解亏损问题。这些题目不仅仅要求学生有扎实的数学基础,更需要他们具备出色的分析和判断能力。 课件中还包含了一些涉及资源合理...
通过趣味数学题的练习,我们不仅能够巩固数学知识,还能培养逻辑推理能力和创新意识。 首先,趣味数学题广泛地涵盖了数学的各个领域,如利润计算、年龄问题、追及问题、逻辑推理、排列组合等。比如,在买卖马的利润...
2. 运算符:C语言支持各种算术运算符(+,-,*,/,%),逻辑运算符(&&,||,!)以及比较运算符(==,!=,<,>,,>=)。这些运算符在解决数学问题时用于执行计算、条件判断和逻辑操作。 3. 控制结构:if...else...
例如,第一题关注的是算术运算,这一领域是数学学习的基础,它要求学生掌握基本的运算规则,如同级别的运算法则、括号的使用等。这些问题通过有趣的表达式形式出现,比如(5-1÷5)×5和8÷(3-8÷3),让学生在...
12. 烟头卷烟问题:这是一道简单的算术问题,将25个烟头分成每5个一组,可得出能做成多少支烟。 13. 盒子嵌套问题:这要求学生理解包含关系,计算总共有多少个盒子。 14. 剪指甲问题:这是一个简单的乘法问题,每...
例如,书中可能会有这样一道题:给出一个数字序列,要求找出规律并预测下一个数字。这类题目锻炼的是观察力和逻辑推理能力,需要我们分析数字间的关联,发现隐藏的模式。在解答过程中,我们可能需要用到等差数列、...
在小学一年级的数学学习中,趣味题的设计是为了帮助孩子们在轻松愉快的氛围中掌握数学基础知识。《一年级数学趣味题100道》这本文档,通过一系列与孩子们日常生活紧密相关的问题,让孩子们在解决这些问题的过程中,...
下面,让我们来详细探讨一下,一份二年级趣味数学考试题中可能出现的各种类型题目及其教育意义。 首先,我们来看数量关系与运算。这类题目通常要求学生使用基本的加法和减法来解决问题。例如,假设有一道题目是小鸟...
这些题目涵盖了多个数学知识点,包括基础的算术、比例与分数、代数、几何、以及逻辑推理。让我们逐一解析: 1. 这是一道关于比例和速度的问题。根据题目,大人上楼的速度是小孩的两倍,我们可以设定小孩的速度为v,...
它不仅是一道简单的算术题,更是一个将数学应用于实际生活的问题。通过这样的问题,学生能直观地理解间隔与数量之间的关系,学会了如何将数学规律应用于现实生活中。100米长的公路旁植树,每隔10米种一棵,那么10个...
《强调数字推算的100道趣题》是一本由法国数学家皮埃尔·贝洛坎编著的趣味数学教材,它属于加德纳趣味数学系列,深受国内外读者的喜爱。这本书旨在通过一系列富有挑战性和启发性的数学问题,激发读者对数字推算的...
**第2题:**同样地,这是一道缺失具体信息的单选题。考虑到这是少儿编程的题目,题目内容可能与日常生活中的常识有关,例如食物等。 **第3题:**本题考查的是数学概念“舍入”。正确答案是C项“向下舍入”,这意味...
11. **排列与组合**:第12题是一道关于排列的问题,根据题目描述,可以得出小孩的数量。 12. **逻辑推理**:第13题是基于比例关系的逻辑推理题,需要理解男孩看到的女孩与实际女孩数量的关系。 13. **等比数列**:...
这是一道涉及基本算术运算的题目,学生需要运用乘法和加法来计算总价和数量,同时还要运用平均数的概念。这类题目不仅锻炼了学生的计算能力,还让学生学会了如何处理实际问题,如购物时计算单价和总价。 第二题则是...
1. 文字算式游戏:这是一种利用汉字的数字含义进行数学运算的趣味题目,主要考察学生的逻辑思维和基本的算术能力。例如题中给出的算式(1)至(5),需要将汉字转换为数字,然后进行乘法或加法运算,得出正确答案。 ...
【小学数学100道智力题答案解析】 这些智力题涵盖了小学阶段常见的数学知识点,旨在锻炼...这些智力题覆盖了小学数学的多个领域,包括算术、几何、概率、逻辑推理等,旨在通过实际操作和思考来提高孩子们的数学素养。
选择题部分的考查范围广泛,从基本的算术运算到几何图形的性质,每一道题都旨在巩固学生的基础知识。以题目1到12为例,学生必须运用他们对整数、分数、比和比例的理解来解决实际问题。三角形的性质、线段长度和角度...
这是一道填空题,目标是在数字间插入加减乘除运算符,使得整个表达式的结果等于100。解决此题需要熟悉算术运算符的优先级,并能运用回溯或深度优先搜索等算法。 7. Chapter 4 这部分可能涉及C++的基础概念,例如...
1. 数学运算: resourceName-"马克思手稿中的一道趣味数学题",该题目要求编写程序,采用穷举法求出结果,解决男人、女人和小孩各有几人的问题。 2. 数学运算: resourceName-"编写程序,根据公式求 e 的值",该...
除了常规的算术运算和逻辑推理题之外,文件中还包含了一些图形题和数列题。这些题目着重考察孩子们的观察和分析规律的能力,以及他们对于数量变化和数值组合规律的理解。例如,图形题通常要求学生找出图形变化的模式...