获取题库不需要订阅专栏,可直接私信我进入CSDN领军人物top1博主的华为OD交流圈观看完整题库、最新面试实况、考试报告等内容以及大佬一对一答疑。
题目描述
100个人围成一圈,每个人有一个编码,编号从1开始到100。
他们从1开始依次报数,报到为M的人自动退出圈圈,然后下一个人接着从1开始报数,直到剩余的人数小于M。
请问最后剩余的人在原先的编号为多少?
输入描述
输入一个整数参数 M
输出描述
如果输入参数M小于等于1或者大于等于100,输出“ERROR!”;
否则按照原先的编号从小到大的顺序,以英文逗号分割输出编号字符串
用例
输入 3
输出 58,91
说明 输入M为3,最后剩下两个人。
输入 4
输出 34,45,97
说明 输入M为4,最后剩下三个人。
题目解析
目标:判断给定的数学表达式中括号的使用是否正确,并计算正确匹配的括号对数。
方法:使用一个栈来跟踪括号的使用情况。遍历表达式的每个字符,当遇到左括号时,将其压入栈;当遇到右括号时,检查栈顶是否为左括号,若是则弹出栈顶元素(表示这对括号匹配),否则说明括号使用错误。