IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 题解ABC 255 C -> 正文阅读

[C++知识库]题解ABC 255 C

目录

1.C - ±1 Operation 1

题意

思路

????????1.处理递减序的情况。

??????? 2.二分查找

??????? 3.分类讨论

程序

??????? 方法1:二分查找

???????? 方法2:分类讨论


1.C - ±1 Operation 1

题意

一个操作是指给一个数X加上1或者减掉1.若有个等差数列SN个元素,第一个元素为A,其中的任意一个数叫做好数。请将数X进行0次或以上操作,使其成为好数。那么最少需要多少次操作?

思路

????????1.处理递减序的情况。

只要按下面代码就能编程递增序。就是把第一个变为最后,最后变为第一个。倒序一下数列。

  if(d<0){
    long long fi=a+d*(n-1);
    a=fi;
    d*=-1;
  }

接下来有两种解法将会阐述。请选择适合的一种方法。

??????? 2.二分查找

序列S包括了所有整数k(0\leq k\leq N-1)A+kD。当D>0,序列S就是递增的,所以我们可以通过在S上进行二分找X,查找离k最近的元素。就是二分答案。代码在后面。现在介绍另外一种方法。

??????? 3.分类讨论

类似于数学思想。定义start=A,final=A+(N-1)D,分别为数列中最小与最大的元素。开始分类:

??????? 1.如果X在start与final之间:

  • 如果公差为0,那所有数都是一样的,因而求出答案为0.
  • 否则,对于每个K都满足(0\leq k\leq N-1),数列S包括了A+kD,并且A\leq X\leq A+ (N-1)D,所以答案为\textrm{min}( (X-A)%D,D- (X-A)%D)。这是在把零头比小。因为你也不知道是靠上还是靠下。如果除数为10,模数为1,那么向下;而模数若为8,那么靠上。所以诞生了这条语句。

??????? 2.如果X在start之前:

??????? 答案为start-X;

??????? 3.如果X在final后:

??????? 答案为X-final;

程序

??????? 方法1:二分查找

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main(void)
{
	long long x,a,d,n;
	cin >> x >> a >> d >> n;
	if(d<0)
	{
	    ll fi=a+d*(n-1);
	    a=fi;
	    d*=-1;
	}
	ll st=0,fi=(n-1);
	while(st<=fi)
	{
	    ll mid=(st+fi)/2;
	    if(a+d*mid<x)
			st=mid+1;
	    else
			fi=mid-1;
	}
	ll res=8e18;
	for(ll i=max(0ll,st-5); i<=min(n-1,st+5);i++)
	    res=min(abs(a+d*i-x),res);
	cout<< res;
	return 0;
}

???????? 方法2:分类讨论

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll a,x,d,n;
int main(void)
{
	cin>> x>> a>> d>> n;
	if(d<0)
	{
		ll fi=a+d*(n-1);
		a=fi;
		d*=-1;
	} 
	ll st=a,fi=a+d*(n-1);
	if(x>=st && x<=fi)
	{
		ll m;
		if(d!=0)
			m=(x-st)%d;
		else
			m=0;
		cout<<min(m,d-m);
	}
	else if(x<st) cout<<st-x;
	else cout<<x-fi; 
	return 0;
}

?Bye bye!(蒟蒻作此文,有刺快来挑!)

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-04 22:37:15  更:2022-07-04 22:38:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 7:03:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码