Codeforces 365C - Matrix(hash + yy)

题意:给定你一个数串s,再给你一个 a ,问你在矩阵d(第i,j个元素为si*sj)有多少个小矩形的和为a

解题思路:可知  a = (s[x] + s[x+1] + ....s[y])* (s[p]+s[p+1]+....s[q]);    我们只需要枚举各字串的和以及其个数就可以得到所求小矩形的个数

解题代码:

 1 #include <stdio.h>
 2 #include <string.h>
 3 char a[4005];
 4 __int64 b[4005];
 5 __int64 hs[40005];
 6 __int64 sum[4005];
 7 int main()
 8 {
 9     __int64 k ;
10     scanf("%I64d",&k);
11     scanf("%s",a);
12     memset(hs,0,sizeof(hs));
13     __int64 len = strlen(a);
14     for(__int64 i= 0 ;i < len ;i ++)
15     {
16         b[i+1] = a[i] - '0';
17     }
18     sum[0] = 0 ;
19     sum[1] = b[1];
20     for(__int64 i = 1;i <= len;i ++)
21         sum[i] = sum[i-1] + b[i];
22 
23     for(__int64 i = 0;i <= len;i ++)
24         for(__int64 j = i+1; j<= len ; j ++ )
25         {
26             hs[sum[j] - sum[i]] ++;
27         }
28 
29     //  printf("%I64d %I64d\n",hs[0],hs[1]);
30         __int64 ans = 0 ;
31         if(k != 0 ){
32             for(__int64 i = 1;i <= 40000;i ++)
33             {
34                 if(k % i == 0  &&  (k / i) <= 40000)
35                     ans += hs[i] * hs[k/i];
36             }
37         }
38         else
39         {
40             ans = hs[0] *hs[0];
41             for(int i = 1 ;i <= 40000;i ++)
42                 ans += hs[i]*hs[0]*2;
43 
44         }
45         printf("%I64d\n",ans);
46         return 0;
47 }
View Code

 

转载于:https://www.cnblogs.com/zyue/p/3434319.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/294620.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

耗时3年,集齐102位中国摄影师,央视这部纪录片BBC也无法超越......

全世界只有3.14 % 的人关注了爆炸吧知识地球上已知的植物有三十多万种&#xff0c;其中十分之一生长在中国。这些植物不仅为中国带来福祉&#xff0c;还不断迁徙到世界各地。在人类的不懈努力下&#xff0c;它们又获得了新的姿态&#xff0c;为不同的文明带来不一样的色彩。《影…

十五天精通WCF——第十一天 如何对wcf进行全程监控

说点题外话&#xff0c;我们在玩asp.net的时候&#xff0c;都知道有一个叼毛玩意叫做“生命周期”&#xff0c;我们可以用httpmodule在先于页面的page_load中 做一些拦截&#xff0c;这样做的好处有很多&#xff0c;比如记录日志&#xff0c;参数过滤&#xff0c;全局登录验证等…

Android之MVP 模式:简单易懂的介绍方式

转载&#xff1a;https://segmentfault.com/a/1190000003927200 Android MVP Pattern Android MVP 模式1 也不是什么新鲜的东西了&#xff0c;我在自己的项目里也普遍地使用了这个设计模式。当项目越来越庞大、复杂&#xff0c;参与的研发人员越来越多的时候&#xff0c;MVP 模…

mysql dw解决方案_MySQL 的 DW 解决方案(MySQL + Infobright)

随着 BI (DW) 在各个企业中重要性的不断提升&#xff0c;各个数据库厂家都希望能搭上这辆班车。这不&#xff0c;MySQL 也联合 Infobright 一起推出了开源的 数据仓库解决方案&#xff0c;而且是开源的。 其实现的各种DW该有的功能就不多说了&#xff0c;但是 Infobright 有一点…

【原】Python基础-函数

#不定长参数&#xff0c;这里prams是一个元组集合def print_params(*prams): for e in prams: print(e) print(prams) #输出(xxx, (1, 2, 3), hello) print_params("xxx", (1,2,3), "hello") #关键字参数&#xff0c;使用参数名提供的参数&#xff0c;主要…

EasyNetQ操作RabbitMQ

EasyNetQ 是一个容易使用&#xff0c;专门针对RabbitMQ的 .NET API。EasyNetQ是为了提供一个尽可能简洁的适用与RabbitMQ的.NET类库。下面看下怎么集成。1、nuget 安装2、配置连接串public static IBus CreateMessageBus(){// 消息服务器连接字符串var connectionString Confi…

男人穿女友的丝袜,只有0次和无数次....

全世界只有3.14 % 的人关注了爆炸吧知识男人爱穿丝袜是刻在基因里的今天是上班第二天&#xff0c;想必很多模友都还没有进入状态&#xff0c;所以超模君准备了一波奇奇怪怪的知识&#xff0c;给各位模友提提神。咱们要讲的&#xff0c;是一种让不少直男听了老脸一红的贴身衣物—…

使用gulp-connect实现web服务器

安装插件安装gulp-connect插件&#xff0c;安装命令如下 npm install --save-dev gulp-connect 定义web服务&#xff0c;gulpfile.js代码 var gulp require(gulp),connect require(gulp-connect), //实现web服务器插件gulp.task(default, function() { });//使用connect实现w…

Android之基于xmpp openfire smack开发之openfire介绍和部署[1]

http://blog.csdn.net/forlong401/article/details/33730365 前言 Java领域的即时通信的解决方案可以考虑openfiresparksmack。当然也有其他的选择。 Openfire是基于Jabber协议(XMPP)实现的即时通信服务器端版本&#xff0c;目前建议使用3.8.1版本&#xff0c;这个版本是当前最…

mysql对null排序_mysql中null值的排序问题分析_MySQL

bitsCN.commysql中null值的排序问题分析如下表t_user&#xff1a;name agezhangsan 1lisi NULLwangwu 2执行一下sql&#xff1a;Sql代码select * from t_user order by age;name agelisi NULLzhangsan 1wangwu 2实际上我们是想将没有填写age的记录放在最后&#xff0c;我们可以…

1988-B. 有序集合

描述 在C里&#xff0c;有一个神奇的东西&#xff0c;叫做STL&#xff0c;这里提供了很多简单好用的容器&#xff0c;用来实现常用又很难书写的数据结构&#xff0c;如栈&#xff08;stack&#xff09;等。其中&#xff0c;有一个容器叫set&#xff0c;译作“有序集合”。首先&…

silverlight中数据绑定讲解

2019独角兽企业重金招聘Python工程师标准>>> 下面我们开始讲解silverlight中一个比较重要的知识——数据绑定。 我们对于数据绑定并不陌生&#xff0c;在我们ASP.NET中就涉及到了数据绑定&#xff0c;像我们之前学的DataList&#xff0c;GridView&#xff0c;repeat…

恋爱后能有多认真?

1 北方孩子有起床困难户吗&#xff1f;▼2 如果我有10万死士&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼3 只有小天才手表&#xff08;素材来源豆瓣&#xff0c;侵删&#xff09;▼4 给你一万刀&#xff0c;扇你的好朋友▼5 这才是一个模特该有的身材&#xf…

.NET 6 新特性 PeriodicTimer

.NET 6 新特性 PeriodicTimerIntro.NET 6 中引入了一个新的 Timer —— System.Threading.PeriodicTimer&#xff0c;和之前的几个 Timer 相比一个最大的区别就是&#xff0c;新的 PeriodicTimer 的事件处理可以比较方便地使用异步方式&#xff0c;消除了使用 callback 的机制…

Android之基于xmpp openfire smack开发之smack类库介绍和使用[2]

http://blog.csdn.net/shimiso/article/details/8816540 关于Smack编程库&#xff0c;前面我们提到&#xff0c;它是面向Java端的api&#xff0c;主要在PC上使用&#xff0c;利用它我们可以向openfire服务器注册用户&#xff0c;发送消息&#xff0c;并且可以通过监听器获得此…

团队介绍

团队成员&#xff1a;孙哲&#xff0c;何琳琳&#xff0c;张一博&#xff0c;李营成员特点&#xff1a;孙哲&#xff1a;我们组的核心力量&#xff0c;擅长编程&#xff0c;对C&#xff0c;Java都有很好的掌握&#xff0c;何琳琳&#xff1a;热爱学习&#xff0c;积极向上&…

简单明了区分escape、encodeURI和encodeURIComponent

一、前言 讲这3个方法区别的文章太多了&#xff0c;但是大部分写的都很绕。本文试图从实践角度去讲这3个方法。 二、escape和它们不是同一类 简单来说&#xff0c;escape是对字符串(string)进行编码(而另外两种是对URL)&#xff0c;作用是让它们在所有电脑上可读。编码之后的效…

python 线程 的类库_python类库32[多线程]

一 python 多线程因为CPython的实现使用了Global Interpereter Lock(GIL)&#xff0c;使得python中同一时刻只有一个线程在执行&#xff0c;从而简化了python解释器的实现&#xff0c;且python对象模型天然地线程安全。如果你想你的应用程序在多核的机器上使用更好的资源&#…

SQL Server 排序规则(摘)

3Sql Server数据库&#xff0c;在跨库多表连接查询时&#xff0c;若两数据库默认字符集不同&#xff0c;系统就会返回这样的错误&#xff1a;“无法解决equal to操作的排序规则冲突” 一、错误分析&#xff1a; 这个错误是因为排序规则不一致造成的&#xff0c;比如&#xff1…

当.NET遇到机器学习

微软中国MSDN 点击上方蓝字关注我们ML.NET 是面向 .NET 开发人员的开源跨平台机器学习框架&#xff0c;你可以使用 C# 或 F# 创建自定义 ML 模型&#xff0c;而无需离开.NET 生态系统。ML.NET 使你能够在联机或脱机场景中将机器学习添加到 .NET 应用程序中。借助此功能&#x…