俄罗斯方块

俄罗斯方块

https://www.nowcoder.com/practice/9407e24a70b04fedba4ab3bd3ae29704?tpId=98&tqId=32832&tPage=1&rp=1&ru=/ta/2019test&qru=/ta/2019test/question-ranking

题目难度:一星
考察点:模拟、计数

方法:模拟、计数

  1. 分析:
    由于整个屏幕有n列,那么如果想要得分的话就要从第1列到第n列都要有值才能得分,那么我们只需要对每个方块落在第几列进行计数,然后从第1列一直循环到第n列,判断哪列的计数值最小,最小值就是答案,输出即可。
    举个例子:
    3 6
    1 2 3 1 1 2
    上例表示一共有三列,6个1*1的方块,那么我们统计一下每一列的方块数:
    第一列:有3个(数字1有三个)
    第二列:有2个(数字2有二个)
    第三列:有1个(数字3有一个)
    所以以每列的个数最小值为最终答案,即小易能够得1分。

算法实现:
(0). 输入x,用一个数组用来计数a[x]++
(1). 从第1列遍历到第n列,找到计数数组的最小值
(2). 输出最终最小值结果

  1. 复杂度分析:
    时间复杂度:O(n)
    空间复杂度:O(n)

  2. 代码:

    #include <bits/stdc++.h>
    using namespace std;
    typedef long long LL;
    const int MAXN = 1e3+5;
    int a[MAXN];
    int main() {
     int n, m; cin>>n>>m ;
     for(int i=0; i<m; i++) {
         int x; cin>>x;
         a[x]++;
     }
     int ans = m;
     for(int i=1; i<=n; i++) ans = min(ans, a[i]);
     cout<<ans<<endl;
     return 0;
    }
全部评论
系统自带。。。
点赞 回复 分享
发布于 2020-05-23 15:06
min函数都没有定义
点赞 回复 分享
发布于 2020-05-15 20:08

相关推荐

牛客21331815...:像我一投就pass,根本不用焦虑泡池子
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 你的mentor是什么样的人? #
3895次浏览 28人参与
# 你觉得mentor喜欢什么样的实习生 #
10253次浏览 284人参与
# 平安产险科技校招 #
2404次浏览 0人参与
# 帮我看看,领导说这话什么意思? #
6110次浏览 25人参与
# 没有家庭托举的我是怎么找工作的 #
12292次浏览 158人参与
# 怎么给家人解释你的工作? #
1371次浏览 16人参与
# 智慧芽求职进展汇总 #
17812次浏览 106人参与
# 求职低谷期你是怎么度过的 #
5208次浏览 91人参与
# 26届秋招公司红黑榜 #
11934次浏览 41人参与
# 从哪些方向判断这个offer值不值得去? #
6545次浏览 93人参与
# 同bg的你秋招战况如何? #
158817次浏览 927人参与
# 度小满求职进展汇总 #
10078次浏览 51人参与
# 实习必须要去大厂吗? #
146625次浏览 1541人参与
# 校招泡的最久的公司是哪家? #
4482次浏览 22人参与
# 你有哪些缓解焦虑的方法? #
37173次浏览 835人参与
# 面试紧张时你会有什么表现? #
1694次浏览 20人参与
# 你喜欢工作还是上学 #
77572次浏览 860人参与
# 入职第一天,你准备什么时候下班 #
85471次浏览 467人参与
# 秋招想进国企该如何准备 #
97706次浏览 487人参与
# 简历无回复,你会继续海投还是优化再投? #
103582次浏览 819人参与
# 机械人的工作环境真的很差吗 #
25014次浏览 119人参与
# 独居后,你的生活是更好了还是更差了? #
28125次浏览 263人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务