算法提高之夏洛克和他的女朋友

算法提高之夏洛克和他的女朋友

  • 核心思想:筛质数

    • 因为质因子与其合数不能为同一个颜色
    • 所以将质数分一组 合数分一组 那么一定符合要求
    • 结果颜色数量<=2:在n<=2时为1种颜色 >2时为2种颜色
cpp 复制代码
  #include <iostream>
  #include <cstring>
  #include <algorithm>
  
  using namespace std;
  const int N = 100010;
  
  int prime[N],cnt;
  bool st[N];
  
  void get_prime(int n)
  {
      for(int i=2;i<=n;i++)
      {
          if(!st[i]) prime[cnt++] = i;
          for(int j=0;prime[j] * i <= n;j++)
          {
              st[prime[j]*i] = true;
              if(i % prime[j] == 0) break; 
          }
      }
  }
  
  int main()
  {
      int n;
      cin>>n;
      get_prime(n+1);
      if(n<=2) cout<<1<<endl;
      else cout<<2<<endl;
      for(int i=2;i<=n+1;i++)
      {
          if(st[i]) cout<<"2 ";
          else cout<<"1 ";
      }
  }
相关推荐
艾莉丝努力练剑几秒前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Once_day16 分钟前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
Trouvaille ~26 分钟前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
偷吃的耗子31 分钟前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
坚果派·白晓明37 分钟前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
小镇敲码人1 小时前
深入剖析华为CANN框架下的Ops-CV仓库:从入门到实战指南
c++·python·华为·cann
dazzle1 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵1 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann
张张努力变强2 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法