博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AC日记——N的倍数 51nod 1103
阅读量:6603 次
发布时间:2019-06-24

本文共 1917 字,大约阅读时间需要 6 分钟。

 

思路:

  先计算出前缀和;

  然后都%n;

  因为有n个数,所以如果没有sum[i]%n==0的化,一定有两个取模后的sum相等;

  输出两个sum中间的数就好;

 

来,上代码:

#include 
using namespace std;#define maxn 50005int n,ai[maxn],sum[maxn],ioss[maxn];inline void in(int &now){ register char Cget=getchar();now=0; while(Cget>'9'||Cget<'0') Cget=getchar(); while(Cget>='0'&&Cget<='9') { now=now*10+Cget-'0'; Cget=getchar(); }}int main(){ in(n); for(int i=1;i<=n;i++) in(ai[i]),sum[i]=(sum[i-1]+ai[i])%n; for(int i=1;i<=n;i++) { if(sum[i]==0) { printf("%d\n",i); for(int j=1;j<=i;j++) printf("%d\n",ai[j]); return 0; } if(ioss[sum[i]]==0) ioss[sum[i]]=i; else { int pos=ioss[sum[i]]; printf("%d\n",i-pos); for(int j=pos+1;j<=i;j++) { printf("%d\n",ai[j]); } return 0; } } printf("No Solution\n"); return 0;}

 疯狂优化没什么卵用版:

#include 
int n,u[50001],s[50001],o[50001];inline void w(register int x){ if(x>9) w(x/10); putchar(x%10+48);}int main(){ scanf("%d",&n); int *a=&u[0],*b=&s[0]; for(int i=1;i<=n;i++) { a++,b++; register char Cget=getchar();*a=0; while(Cget>'9'||Cget<'0') Cget=getchar(); while(Cget>='0'&&Cget<='9') { *a=*a*10+Cget-'0'; Cget=getchar(); } *b=(s[i-1]+*a)%n; if(*b==0) { w(i),putchar('\n'); for(register int *p=&u[1];p!=&u[i+1];p++) w(*p),putchar('\n'); return 0; } if(o[*b]==0) o[*b]=i; else { int pos=o[*b]; w(i-pos),putchar('\n'); for(register int *p=&u[pos+1];p!=&u[i+1];p++) w(*p),putchar('\n'); return 0; } } printf("No Solution\n"); return 0;}

 

转载于:https://www.cnblogs.com/IUUUUUUUskyyy/p/6718227.html

你可能感兴趣的文章
【前端笔记】彻底理解变量与函数的声明提升
查看>>
PHP工具箱:PHPStan —— PHP 静态代码分析工具
查看>>
iOS - 多链式动画框架 LSAnimator
查看>>
Android 反编译利器,jadx 的高级技巧
查看>>
Mycat 读写分离 数据库分库分表 中间件 安装部署
查看>>
二叉搜索树(递归实现)
查看>>
Spring Retry重试机制
查看>>
Android官方架构组件LiveData: 观察者模式领域二三事
查看>>
第七章——字符串(不定长度字符)
查看>>
Cocoapods 创建第三方框架
查看>>
[Android组件化]组件化数据分享
查看>>
[转]23个最有用的Elasticsearch检索技巧
查看>>
你必须知道的HTTP基本概念
查看>>
当下拉列表数据过大时,该如何应对?
查看>>
使用OpenGrok搭建 可搜索可跳转的源码 阅读网站
查看>>
HTML5开发中的javascript闭包
查看>>
Android ContentProvider调用报错"Bad call:..."及相关Binder权限问题分析
查看>>
你真的会用strong-weak dance吗?
查看>>
ionic3 教程(二)登录页制作
查看>>
Python正则表达式初识(四)
查看>>