没讲明白的水题orz
有一道解释程序的水题没给非计算机专业的同学讲明白orz,在这里再练一下。。
源代码完全没有缩进真是难以忍受。。
p.s.懂递归就不用看了#include <stdio.h>
int n = 0; int rest[7][7]; void swap(int *a, int *b) { int m; m = *a; *a = *b; *b = m; } void perm(int list[], int k, int m) { int i; int j; if(k > m) { for (i=0; i<7; i++)//判断list是否可行,不行就返回,行就输出list { for (j=0; j<7; j++) { if (rest[i][j] == 0) return; if (rest[i][j] != list[i])//list存结果 continue; if (rest[i][j] == list[i]) break; } } n++; printf("Solution: %d\n", n); printf("赵 钱 孙 李 周 吴 陈\n"); printf("=============================================================\n"); for(i = 0; i <= m; i++) { switch (list[i]) { case 1: printf("星期一 "); break; case 2: printf("星期二 "); break; case 3: printf("星期三 "); break; case 4: printf("星期四 "); break; case 5: printf("星期五 "); break; case 6: printf("星期六 "); break; case 7: printf("星期日 "); break; default: break; } } printf("\n\n\n"); } else { for(i = k; i <= m; i++)//实验所有可能的list的组合,7!次 { swap(&list[k], &list[i]); perm(list, k + 1, m); swap(&list[k], &list[i]); } } } int main() { printf("\n"); printf("注意:\n"); printf(" 1.请按钱、赵、孙、李、周、吴、陈的顺序输入休息每个人的时间。\n"); printf(" 2.输入星期时,请直接输入数字,如要输入'星期一',就用'1'代替,以此类推。\n"); printf(" 3.星期与星期之间用空格隔开,每输入完一个人的休息日,在其后输入0,再按回车继续下一人。\n"); printf("\n"); int list[] = {1, 2, 3, 4, 5, 6, 7}; int i, j; for(i = 0; i < 7; i++) { printf("请输入第 %d 个人的休息时间:\n", i+1); for(j = 0; j < 7; j++) { scanf("%d", &rest[i][j]); if(rest[i][j] == 0) break; } } printf("\n\n\n"); perm(list, 0, 6); getchar(); getchar(); printf("输出完毕,按回车键结束!\n"); return 0; }
0.看见swap用来交换
1.这么一坨代码首先看main,了解到输入的rest数组是每个人的希望的休息时间。
2.看见用rest【i】[j]与list[i]进行比较,下文将list转换成星期几输出,那么list应该是保存的结果。
两个for循环是判断list是否可行。对于list[x],查找对应的第x人的愿望单里有没有这个数字,有就找下一个人,全通过了意味着方案可行,下面用来输出list;没有就返回上一层函数;
3.重点是这里,用了递归
for(i = k; i <= m; i++)// { swap(&list[k], &list[i]); perm(list, k + 1, m); swap(&list[k], &list[i]);
程序的主要思路为尝试从1到7的数字的所有组合,如果符合条件,就输出。这样一共要进行7!次测试。
那么如何进行从一到七的全排列呢? 先看一下我们怎么全排列 1 2 3。
一共可以排列的方式如下:
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
我们让不同的数字分别打头,然后交换剩下的数字。 更近一步:如何进行1到4的全排列呢?
同样的,我们让不同的数字打头。
1 int[3](开头数字1,后面是一个长度为3的数组)
......
2 int[3]
......
......
4 int[3]
我们把打头数字相同的看做一组数字,这样一共有4组数字。
对于每组数字,我们需要将他们尾部的数组全排列,也就是重复四次上面排列1 2 3的方法,注意每次操作对象不同。一共操作4*(3*2)次
从 1到5也是同理,我们将他们分为5组。
1 [4]
2 [4]
.....
5 [4]
对于每组数,我们将它尾部的数组用上面排列4个元素的方法进行排列,而排列4个元素的方法又要用到排列3个元素的方法,排列3个元素又要用到排列2个元素的方法。
于是总排列次数为5*4*3*2*1=120次 我们看到,每次排列都要用到比自己更小的数的排列方法,排列x个数方案为x!。
现在我们回来看代码。 排列1到7,我们需要排列7!次。首先要把1到7分成七组,让每个数字轮流打头。
所以 for{swap..}。(在末尾的时候你必须要把元素换回来,要不换下一个数时数组就乱了。所以结尾也要swap();)
在这7次循环中,每次你都要用到排列后面6个数的方法,用到6次自己,只需要调用自己,把参数改成6就行了,所以
for(....)
swap()
perm()
swap()
而排列6个数就要用到排列5个数的方法,这样一直下去函数一共嵌套了7层,第1层执行7遍,第2层执行6遍,以此类推,一共执行7!遍.
——————————————————————————
emmmmmmmm还没懂我就再改改
没讲明白的水题orz的更多相关文章
- 【Floyd(并非水题orz)】BZOJ4093-[Usaco2013 Dec]Vacation Planning
最近刷水太多标注一下防止它淹没在silver的水题中……我成为了本题,第一个T掉的人QAQ [题目大意] Bovinia设计了连接N (1 < = N < = 20,000)个农场的航班. ...
- 史上最明白的 NULL、0、nullptr 区别分析(老师讲N篇都没讲明白的东东),今天终于明白了,如果和我一样以前不明白的可以好好的看看...
C的NULL 在C语言中,我们使用NULL表示空指针,也就是我们可以写如下代码: int *i = NULL; foo_t *f = NULL; 实际上在C语言中,NULL通常被定义为如下: #def ...
- 说一说ST表 讲一讲水题
ST表 一.算法介绍 如何快速求解RMQ问题呢?暴力复杂度O(n),线段树复杂度O(n)~O(logn),要是数据规模达到10^7或者更高呢?我们需要一种可以做到O(1)查询的算法,这时就可以用到ST ...
- 搜索 水题&&错误集锦
引子: 本以为搜索的题目老师也不会检查,结果今天早上loli慢悠悠的说:“请同学们提交一下搜索的题目~”,顿时心旌摇曳,却也只能装作镇定自若的样子,点了点头.. 然后就开始了今天的疯狂做题,虽说题目都 ...
- Codeforces Round #190 (Div. 2) 水果俩水题
后天考试,今天做题,我真佩服自己... 这次又只A俩水题... orz各路神犇... 话说这次模拟题挺多... 半个多小时把前面俩水题做完,然后卡C,和往常一样,题目看懂做不出来... A: 算是模拟 ...
- BZOJ USACO 银组 水题集锦
最近刷银组刷得好欢快,好像都是水题,在这里吧他们都记录一下吧(都是水题大家一定是道道都虐的把= =)几道比较神奇的题到时再列出来单独讲一下吧= =(其实我会说是BZOJ蹦了无聊再来写的么 = =) [ ...
- Atcoder 水题选做
为什么是水题选做呢?因为我只会水题啊 ( 为什么是$Atcoder$呢?因为暑假学长来讲课的时候讲了三件事:不要用洛谷,不要用dev-c++,不要用单步调试.$bzoj$太难了,$Topcoder$整 ...
- 【转】POJ百道水题列表
以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...
- Disillusioning #1 水题+原题赛(被虐瞎)
https://vijos.org/tests/542c04dc17f3ca2064fe7718 好一场 水题 比赛啊 t1直接上暴力费用流10分QAQ,虽然一开始我觉得可以不用的,直接dfs可以得出 ...
随机推荐
- BZOJ-3105: 新Nim游戏 (nim博弈&线性基)
pro: 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个火柴堆拿走若干根火柴.可以只拿一根,也可以拿走整堆火柴,但不能同时从 ...
- 在qt creator中使用imread并将图片显示到QLable中时没反应
调试时发现Mat m = imread("")函数运行了,但是将鼠标放在m上面时,发现m是空的,但是竟然能往下运行,简直恶心,于是我在后面加上判断m.empty(),发现返回了tu ...
- 让你真正了解Java(纯干货)
“你学习一门技术的最佳时机是三年前,其次是现在.”这句话对于哪一种行业都很适用,如果你已经学习过Java,那么恭喜你你很有先见之明,如果你并不了解Java,这篇文章带你快速掌握Java的几个核心知识点 ...
- MATLAB EMD 初始
帮小伙伴研究这个 随便写写 安装参考https://blog.csdn.net/qrlhl/article/details/52213135 函数学习: disp函数 : 1.disp函数:显示文本 ...
- 迁移32位下的旧代码到64位sever遇到过的两个很诡异的问题
一个是GetHashCode,这个方法是返回一个int值,在32位系统里,都是正值,但在64位系统里会返回负值. 另一个问题是DataTable的Sort属性,在没有显示写明升序或降序的情况下,在32 ...
- python中使用if __name__ == '__main__':
引子 在python中,假设在一个test1.py的模块中定义了一个foo函数,然后调用函数foo进行测试的时候会产生一个内存空间.当你把这个模块导入到test2.py模块中,接下来如果在test2. ...
- 面试题-Python高级
元类 Python 中类方法.类实例方法.静态方法有何区别? 类方法:是类对象的方法,在定义时需要在上方使用“@classmethod”进行装饰,形参为cls, 表示类对象,类对象和实例对象都可调用: ...
- source-insight 常用操作
[Ctrl + ] 跳转到函数.宏.变量 等定义处. [Alt > ] 跳转到最近光标停留位置. [Alt < ] 跳转到上次近光标停留位置. [Ctrl Shift [ ] 块位置开 ...
- 当鼠标经过表格数据行时颜色不同且奇偶行颜色也不同 (纯CSS)
<!DOCTYPE html> <!-- To change this license header, choose License Headers in Project Prope ...
- 模板语言 自定义函数simple_tag
模板语言自带的一些处理函数:通过管道符来处理 帮助方法:{{ item.event_start|date:"Y-m-d H:i:s"}} 转换成日期时间型{{ bio|trunc ...