打表法经典2题:小于n的质数和第k个丑数

2023-11-11

1 求小于n的所有质数

1 开一个大小为n的bool数组A,下标代表整数,值true代表被mark过,有因子,非素数

2) i 从 2开始到n - 1,如果A[i]没被mark,A[i]就是质数,然后mark有A[i]因子的数(2* A[i], 3*A[i], 4*A[i] 且< n) 这里注意,系数实际不需要从2开始,而是从A[i]开始,即从A[i] *A[i] 看起,因为更小的数之前check 过了。

public int countPrimes(int n) {
    boolean[] marked = new boolean[n];
	int count = 0;
	for (int i = 2; i < n; ++i) {
		if (!marked[i]) {
			++count;
			for (long j = (long)i * i; j < n; j += i) marked[(int)j] = true;
		}
	}
	return count;
}

2 求前k个丑数(因子里只有2,3,5的数,习惯上1作为第一个丑数,所以1, 2,3,4,5都是丑数)

开一个因子数组A{2,3, 5}和一个前k个丑数的动态数组V,初始化为{1,2,3,4,5}

不断加进新的丑数,直到V的size 达到k,,v.back() 就是答案。

得到下一个丑数的做法就是枚举3个因子{2,3,5}和已找到的丑数的乘积,对于一个因子A[i],A[i]*V[j] 第一次大于 v.back()就break,  这个数是下一个丑数的一个可能的candidate,换下一个因子,同样的逻辑。下一个丑数是每个因子的candidate中最小的那一个。

这里需要优化一下的是,对于每个因子纪录一个刚超过b.back()对应的丑数数组中相乘的那个数的下标,每次找candidate的时候不是位置0开始,而是从这个位置开始

long long kthPrimeNumber(int k) {
    long long w[] = {2, 3, 5}, t[] = {0, 0, 0};
    vector<long long> v = {1, 2, 3, 4, 5}
    if (k <= v.size()) return v[k - 1];
    
    while (v.size() < k) {
        long long x = LONG_MAX;
        for (int i = 0; i < 3; i++) {
            for (int j = t[i]; j < v.size(); j++) {
                if (w[i] * v[j] > v.back()) {
                    x = min(x, w[i] * v[j]);
                    t[i] = j;
                    break;
                }
            }
        }
        v.push_back(x);
    }
    return v.back();
}


丑数问题也可以用堆,类似杨氏矩阵求第k小,即,每得到下一个丑数,把这个数和 {2, 3, 5 } 相乘的结果加进堆,只不过这个堆要支持去重,所以实际用set 做

这一类问题的特点:从小到大输出序列,每输出一个值,把和这个值相邻的序列值放入堆。


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

打表法经典2题:小于n的质数和第k个丑数 的相关文章

  • c语言基础五子棋,十分的易懂理解,详细解释,容易上手

    前言 提示 经过b站和视频学习后编程 提示 以下是本篇文章正文内容 下面案例可供参考 文章目录 前言 五子棋 头文件 展示棋盘 display 下棋 PlayMove 主体函数 game 完整代码 五子棋 本篇博客主要写了关于c语言的五子棋
  • MySQL主从搭建-Centos实战

    目录 一 规划说明 二 主节点安装MySQL 1 下载MySQL和安装 2 启动Mysql 设置root密码 允许远程登录 三 副节点安装MySQL 参考主节点 四 主节点配置 1 配置my cnf 修改默认存储目录为指定目录 data 下

随机推荐

  • 解决SQL查询总是超时已过期

    解决SQL查询总是超时已过期 在WIN8里提示 OLE DB 或 ODBC 错误 查询超时已过期 HYT00 1 由于数据库设计问题造成SQL数据库新增数据时超时 症状 Microsoft OLE DB Provider for SQL S
  • web前端页面适配方法

    流式布局 就是百分比布局 非固定像素 内容向两侧填充 理解成流动的布局 称为流式布局 视觉窗口 viewport 是移动端特有 这是一个虚拟的区域 承载网页的 承载关系 浏览器 gt viewport gt 网页 适配要求 1 网页宽度必须
  • c++基础十一(跳转语句)

    跳转语句 1 break 2 continue 3 goto 1 break 作用 跳出循环结构和选择结构 1 switch语句中 用于终止case并跳出switch语句 2 在循环结构中 用于跳出当前循环 3 在嵌套循环语句中 跳出最近的
  • 企业微信 => 接入第三方vue应用 第三阶段:企业微信使用JSSDK

    目录 使用说明 官方文档不会告诉你的内容 都是会踩的坑 一 我采用的混入方法去使用这个官方SDK 二 可能会遇到的坑 前提 我们开发的是三方应用 不是内部应用 使用说明 所有的JS接口只能在企业微信应用的可信域名下调用 包括子域名 且可信域
  • 深度学习环境搭建( Tensorflow & PyTorch)

    前言 硬件配置 基础软件 1 安装VC redist x64 2 安装显卡驱动并确定算力 3 确认cuda版本 4 安装CUDA 配置cudnn 5 安装Anaconda 6 安装PyCharm 深度学习框架Tensorflow安装 深度学
  • 复习之linux系统中的权限管理

    1 权限的查看及读取 1 权限的查看 ls l file 查看文件的权限 ls ld dir 查看目录权限 2 权限的读取 文件的属性叫做文件的元数据 元数据 Metadata 又称中介数据 中继数据 为描述数据的数据 data about
  • HTML爱心表白代码,亲测有效,独一无二!福利来啦!

    发福利啦 小编最近搜集了好几个表白代码 感兴趣可以点进主页看看哟 如果觉得文章不错 还请一键三联 不定时发布各种全免费的独一无二的代码 这次我们来分享跳动的爱心的代码 网上有很多 但是个人觉得我这个比较温馨一点 背景也好看
  • springboot框架介绍,让我们深入的了解

    Spring Boot是一种用于快速构建基于Spring框架的Java应用程序的开源框架 它旨在简化Spring应用程序的开发过程 通过提供一种约定优于配置的方式 让开发人员能够快速搭建起一个可独立运行的 可部署的 易于扩展的应用 Spri
  • Java的内存机制

    1 Java的内存机制 Java 把内存划分成两种 一种是栈内存 另一种是堆内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配 当在一段代码块定义一个变量时 Java 就在栈中为这个变量分配内存空间 当超过变量的
  • 虚拟化一、虚拟化技术基础原理

    一 虚拟化 虚拟化 是指通过虚拟化技术将一台计算机虚拟为多台逻辑计算机 在一台计算机上同时运行多个逻辑计算机 每个逻辑计算机可运行不同的操作系统 并且应用程序都可以在相互独立的空间内运行而互不影响 从而显著提高计算机的工作效率 虚拟化使用软
  • java字符串转json

    针对不同jar包 一 import org json JSONObject JSONObject jo new JSONObject new String 需要转换的字符串 二 import com alibaba fastjson JSO
  • 巧用机器学习定位云服务器故障

    欢迎大家前往腾讯云 社区 获取更多腾讯海量技术实践干货哦 本文由roganhuang 发表于云 社区专栏 导语 随着腾讯云业务的扩大 母机数量越来越多 为减少人力并实现母机故障的自动化定位 本文尝试利用机器学习算法 通过对历史故障母机的日志
  • 在钉钉上怎么手写_钉钉群上课入门和独家进阶功能(图文)

    钉钉群上课入门和独家快速进阶 在钉钉上有两种视频连接方式 直播和视频会议 两者各有利弊 前者合适人数较多 超过两百人 的时候进行 后者适合一个班级进行上课 下面就两者之间的具体操作说明 文中图片皆可点击放大 一 直播 手机 只有手机怎么直播
  • mysql的连接路径_Mysql 连接路径 url 参数解析

    1 mysql url 参数解析 url jdbc mysql 127 0 0 1 3306 user useUnicode true characterEncoding utf8 useUnicode characterEncoding
  • Webpack构建多页应用Mpa(三):文件结构和自动化打包

    本系列教程整体完成后 会完成一个可用的MPA应用 教程实际就是整个MPA的实现过程的记录 如果是想了解单项功能的实现 请继续往下看 如果是想了解整个MPA的开发和思考过程 建议从 Webpack构建多页应用Mpa 一 阐述设计概要 教程开始
  • 方法:sorttable.js用法

    转至 用sorttable js对表格进行排序 对表格进行排序的实现步骤 第一 下载sorttable js 链接 http www kryogenix org code browser sorttable 不需要jquery js 第二
  • castep 编译安装说明

    科学计算软件编译安装方法说明 castep 篇 提供免费TEST QQ 178068275 1 什么是 castep CASTEP Cambridge Sequential Total Energy Package 的缩写 是一个基于密度泛
  • CNN,RNN,LSTM,GRU的前后向传播算法(梯度是怎么更新的)

    目录 1 简单的梯度计算 2 进阶的梯度计算 3 CNN前向后向算法 4 RNN前向后向算法
  • JavaFx中的Image和ImageView

    image 要转换成ImageView 对象才可以添加到结点中 Override public void start Stage stage stage setTitle 测试窗口 Pane pane new Pane Scene scen
  • 打表法经典2题:小于n的质数和第k个丑数

    1 求小于n的所有质数 1 开一个大小为n的bool数组A 下标代表整数 值true代表被mark过 有因子 非素数 2 i 从 2开始到n 1 如果A i 没被mark A i 就是质数 然后mark有A i 因子的数 2 A i 3 A