ABC#227

2023-11-23 01:58
文章标签 c# .net netcore ab 227

本文主要是介绍ABC#227,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

A

题目大意

n个元素(编号1,2,…),从编号为a的元素开始数起(循环计数),数到k的元素是哪一个。

#include <iostream>
using namespace std;int main()
{int n, k, a;cin >> n >> k >> a;int res = (a + k - 1) % n;if (res == 0) res = n;cout << res;return 0;
}

C

题目大意

给定一个数N,求出满足: a ≤ b ≤ c 且 a × b × c ≤ N a ≤ b ≤ c \ 且\ a\times b\times c ≤N abc  a×b×cN的三元组 ( a , b , c ) (a,b,c) (a,b,c)的个数。

naive方法(TLE)

int n, cnt = 0;
cin >> n;
for (int i = 1; i <= n; i ++)for (int j = i; j <= n; j ++)for (int k = j; k <= n; k ++)if (i * j * k <= n) cnt ++;
cout << cnt;

简单优化
由题意可确定a,b,c的范围分别为: 1 ≤ a ≤ n 3 , a ≤ b ≤ N a , b ≤ c ≤ N a b 1≤a≤\sqrt[3]{n},a\le b\le \sqrt{\frac{N}{a}},b\le c\le\frac{N}{ab} 1a3n abaN bcabN

仍然TLE

int n, cnt = 0;
cin >> n;
for (int i = 1; i*i*i <= n; i ++)for (int j = i; j*j <= n/i; j ++)for (int k = j; k <= n/i/j; k ++)if (i*j*k <= n) cnt ++;
cout << cnt;

注意到:当a,b取定之后,c的范围确定,因此此时c的可取值的个数就随之确定,为 [ N a b ] − b + 1 [\frac{N}{ab}]-b+1 [abN]b+1
因此程序可以改进为:
O ( n 2 3 ) O(n^{\frac{2}{3}}) O(n32)

#include <iostream>
#include <cmath>
using namespace std;
typedef long long LL;int main()
{LL n, cnt = 0;cin >> n;for (LL i = 1; i*i*i <= n; i ++)for (LL j = i; j*j <= n/i; j ++)cnt += n/i/j - j + 1;cout << cnt;return 0;
}

这篇关于ABC#227的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414494

相关文章

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

C# Where 泛型约束的实现

《C#Where泛型约束的实现》本文主要介绍了C#Where泛型约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用的对象约束分类where T : structwhere T : classwhere T : ne

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

C#中DrawCurve的用法小结

《C#中DrawCurve的用法小结》本文主要介绍了C#中DrawCurve的用法小结,通常用于绘制一条平滑的曲线通过一系列给定的点,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 如何使用 DrawCurve 方法(不带弯曲程度)2. 如何使用 DrawCurve 方法(带弯曲程度)3.使用Dr

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘