Help Victoria the Wise CodeForces - 98A
2021/9/15 6:06:24
本文主要是介绍Help Victoria the Wise CodeForces - 98A,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
原题链接
考察:枚举
错误思路:
枚举每一面为正面,给骰子每一面编号,然后求出当前枚举骰子状况每一面为正面的情况,并用字符串记录.
错误原因:
不一定只转一次.....
思路:
参考官方题解:
- 首先先要先知道对于一个已经涂好颜色的正方体,可以有24中旋转方式:选择不同的面作为正面,故而有6种,然后保持该面为正面,可以做4次旋转(没错,就和转把手一样转),得24。
- 第二步要对每个面编号。比如正面为1,右侧为2,上为3……
- 然后我们可以暴力对一个正方体涂色得到一个字符串(以上面编号的顺序),然后再对它进行\(24\)次旋转,得到\(24\)个字符串,取字典序最小的作为当前涂的颜色的代表,存到
set
去重,最后set
的大小就是我们的答案了.
Code
#include <iostream> #include <cstring> #include <set> using namespace std; const int N = 10; string s; set<string> st; int ans; bool vis[N]; string change(int w,string s) { string str = ""; if(w==1) return str = s; if(w==2) { str+=s[3],str+=s[2],str+=s[0]; str+=s[1],str+=s[4],str+=s[5]; } if(w==3) { str+=s[4],str+=s[5],str+=s[2]; str+=s[3],str+=s[1],str+=s[0]; } if(w==4) { str+=s[2],str+=s[3],str+=s[1]; str+=s[0],str+=s[4],str+=s[5]; } if(w==5) { str+=s[1],str+=s[0],str+=s[3]; str+=s[2],str+=s[4],str+=s[5]; } if(w==6) { str+=s[5],str+=s[4],str+=s[3]; str+=s[2],str+=s[1],str+=s[0]; } return str; } string rorate(string s) { string str = s.substr(0,2); str+=s[4]; str+=s[5]; str+=s[3]; str+=s[2]; return str; } void dfs(string str) { if(str.size()==6) { if(!st.count(str)) { ans++; for(int i=1;i<=6;i++) { string sp = change(i,str); for(int j=1;j<=4;j++) st.insert(sp = rorate(sp)); } } return; } for(int i=0;i<s.size();i++) { if(vis[i]) continue; vis[i] = 1; dfs(str+s[i]); vis[i] = 0; } } int main() { cin>>s; dfs(""); printf("%d\n",ans); return 0; }
这篇关于Help Victoria the Wise CodeForces - 98A的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11国产医疗级心电ECG采集处理模块
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南