**********************************************************************************************************************
^_^ ^_^ ^_^ ^_^ ^_^ ^_^ ^_^
1.后面的题解是以前写的,思路并不清晰,只是简单套用知识,也没做分析,也是今天才发现有点不堪入目,所以过来补个题解;
2.也查看了一些其他人的题解,发现对小白不太友好,不过我暂时还简化不了,于是转载修改了一下老师的题解,仅供参考;
**********************************************************************************************************************
解题思路:
由题目可以知道的是
分数和成绩的关系 (二者之和为10) ————(1,9)(2,8) (3,7)..........
第一名是李家,第二名是王家,因为各家名次不连续,所以第三名肯定是张家,接着对其后6个孩子,成绩为1到6分,进行排列判断;
因为各家总分相同(各15分),所以可以推导各家应得总分(减去已知)————张家(15-7),王家(15-8),李家(15-9);
**********************************************************************************************************************
ps:
最后结果为李-王-张-王-李-张-李-张-王;
张家(7,5,3),王家(8,6,1),李家(9,4,2);
**********************************************************************************************************************
参考代码:
#include<iostream> #include<algorithm> #include<cmath> #define N 6 using namespace std; int main() { int score[N]={1,2,3,4,5,6}; char children[N]={'Z','Z','W','W','L','L'}; //各家孩子用两个空间来表示,比如0,1这两个下标是张家的,但里面的元素值是变动的,实质上是内部元素的线性移动(即排列) //直到一种排列满足条件,里面的成绩(名次)固定,但下标依旧不变 do { if(score[0]+score[1]==15-7 && score[2]+score[3]==15-8 && score[4]+score[5]==15-9) { //各家不能连续排名,所以名次差不能为 1 ,绝对值包含前大后小,后小前大两种可能的连续 if( abs(score[0]-score[1])==1 ) continue; if( abs(score[2]-score[3])==1 ) continue; if( abs(score[4]-score[5])==1 ) continue; break;//都满足的话跳出 } }while(next_permutation(score,score+N));//全排列函数(参数不懂的就查阅相关资料哈) //如果是自己写枚举的话,要注意去重; for(int i=0;i<N;i++) if(score[i]==1)//最后一名(成绩为1) cout<<children[i]<<endl; return 0; }
以下不建议查看,黑历史;
#include<iostream> #include<cmath> using namespace std; bool hfd(int a,int b,int c)//判断其余两家是否符合条件 { int cunt=0; for(int i=1;i<=9;i++)//枚举所有情况 { if(i!=a&&i!=b&&i!=c) { for(int j=1;j<=9;j++) { if(j!=a&&j!=b&&j!=c) { for(int k=1;k<=9;k++) { if(k!=a&&k!=b&&k!=c) { if(i+k+j==15&&i!=j&&j!=k&&i!=k&&abs(i-j)!=1&&abs(j-k)!=1&&(i-k)!=1)//每家15分,没有相同得分,且得分不相连; { if(i>j&&j>k)//去重 cunt++;//符合则统计 } } } } } } } if(cunt==2)//两家都符合 return true; else return false; } int main() { for(int i=1;i<=9;i++)//枚举所有情况 { for(int j=1;j<=9;j++) { for(int k=1;k<=9;k++) { if(i+k+j==15&&i!=j&&j!=k&&i!=k&&abs(i-j)!=1&&abs(j-k)!=1&&(i-k)!=1)//每家15分,没有相同得分,且得分不相连; { if(i>j&&j>k)//去重 { if(k==1)//最后一名的那一家 { if(hfd(i,j,k))//判断其余两家是否符合条件 { if(i==9)//李家 cout<<"L"<<endl; else if(i==8)//王家 cout<<"W"<<endl; else//张家 cout<<"Z"<<endl; } } } } } } } return 0;
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复