论坛类的网站怎样做,蛋挞怎么做制作方法,怎么做网站优化推广,谁有做爰网站号网络世界中时常会遇到这类滑稽的算命小程序#xff0c;实现原理很简单#xff0c;随便设计几个问题#xff0c;根据玩家对每个问题的回答选择一条判断树中的路径#xff08;如下图所示#xff09;#xff0c;结论就是路径终点对应的那个结点。 现在我们把结论从左到右顺序…
网络世界中时常会遇到这类滑稽的算命小程序实现原理很简单随便设计几个问题根据玩家对每个问题的回答选择一条判断树中的路径如下图所示结论就是路径终点对应的那个结点。 现在我们把结论从左到右顺序编号编号从 1 开始。这里假设回答都是简单的“是”或“否”又假设回答“是”对应向左的路径回答“否”对应向右的路径。给定玩家的一系列回答请你返回其得到的结论的编号。
输入格式
输入第一行给出两个正整数N≤30为玩家做一次测试要回答的问题数量M≤100为玩家人数。
随后 M 行每行顺次给出玩家的 N 个回答。这里用 y 代表“是”用 n 代表“否”。
输出格式
对每个玩家在一行中输出其对应的结论的编号。
输入样例
3 4
yny
nyy
nyn
yyn输出样例
3
5
6
2
哪需要啥二叉树的思想呀身为基础题这题其实用不了多少思考这题其实就是相当于给了我们一个二进制的编码只是用y和n代替了然后让我们求编号就是把二进制的数转化为十进制的数嘛下面直接给出代码
代码如下
#includeiostream
using namespace std;
int main()
{int n, m;cin n m;while (m--) {string a;cin a;int base 1,sum0;//base为每个位对应的二进制编码2次方的值for (int i a.size() - 1; i 0; i--) {if (a[i] n) sum base;//相当于如果为1这个位的值就要算base * 2;}cout sum1 endl;//二进制转完十进制的数是下标从0开始算的因此要加一满足题意}return 0;
}