16 - 12 - 10 超时(Exceeding Time)问题 优化

2024-01-17 01:32

本文主要是介绍16 - 12 - 10 超时(Exceeding Time)问题 优化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、
Description
Kim刚刚学会C语言中的取模运算(mod)。他想要研究一下一个数字A模上一系列数后的结果是多少。帮他写个程序验证一下。
Input
第一行一个整数T代表数据组数。
接下来T组数据,第一行一个整数n,接下来n个数字ai
接下来一行一个整数m,接下来m个数字bi
Output
对于每个bi,输出bi%a1%a2%…%an
Sample
Input
1
4
10 9 5 7
5
14 8 27 11 25 4

Output
3
2
1
0

Hint
在C语言中,A mod B 是 a%b
样例解释:
14%10%9%5%7=4
8%10%9%5%7=3
数据范围:
1<=n<=100000
1<=m<=100000
1<=ai<=1000000000
0<=bi<=1000000000

↓ 普通方法不超时才怪。

<<<<<< 超 时 代 码 >>>>>>

/*<<<<<< **超 时 代 码** >>>>>>*/#include<stdio.h>
#include<stdlib.h>
#include<cstring>
int main(){int T,i,n,m,j = 0;long a[100000],b[100000];scanf("%d",&T);while(T--){scanf("%d",&n);for(i = 0;i<n;i++){scanf("%d",&a[i]);}scanf("%d",&m);for(i = 0;i<m;i++){scanf("%d",&b[i]);}for(j = 0;j<m;j++){for(i = 0;i<n;i++){b[j] = b[j]%a[i];}printf("%d\n",b[j]);}memset(a,0,sizeof(a));memset(b,0,sizeof(b));n = 0;m = 0;}return 0;
}

<<<<<<正确代码>>>>>>

//<<<<<< **正 确 代 码** >>>>>>/*题解(来自哈理工官方网站):中等题 。  注意到不断取模下去会越来越小,而且一个数模 a 之后再模b,如果 a 比 b 小那么模 b 就没有意义了。所以对输入的 a 数组剔除所有没用的数,剩下一个递减的数组。在这个数组上,每次二分找到距离当前x最接近且大于x的数,模上这个数重复这一过程即可。这个过程不会重复很多次。很快这个数就会小于所有的a,这时就获得了答案。*/#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <iostream>
#define left lll
#define right rrr#define FOR(i,j,k) for(int i=j;i<=k;i++)
using namespace std;
int a[200000+233];
int n,m;
long long  last,left,right,mid,q;
int main (int argc, char *argv[])
{int T;scanf("%d",&T);while (T--){int n;scanf("%d",&n);for(int i=1;i<=n;i++)scanf("%d",&a[i]);last=1;                            //?for(int i=2;i<=n;i++){if ( a[i] < a[last] ){last++;a[last]=a[i];}}n=last;scanf("%d",&m);for(i=1;i<=m;i++){   scanf("%lld",&q);while (1){        //是 1 不是 lleft=0;right=n+1;while ( right - left > 1 ){mid=(right+left)/2 ;if ( a[mid] <= q ){right = mid;}else left = mid;}if (right==n+1) break;q=q%a[right];}printf("%lld\n",q);}}return 0;
}

这篇关于16 - 12 - 10 超时(Exceeding Time)问题 优化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如