CF 191 div2

时间:2020-12-18 04:34:29

A.数据量很小,直接爆搞。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cmath>
#include <cstring>
#include <queue>
#include <set>
#include <vector>
#include <stack>
#include <map>
#include <iomanip>
#define PI acos(-1.0)
#define Max 2505
#define inf 1<<28
#define LL(x) ( x << 1 )
#define RR(x) ( x << 1 | 1 )
#define REP(i,s,t) for( int i = ( s ) ; i <= ( t ) ; ++ i )
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define mp(a,b) make_pair(a,b)
#define PII pair<int,int>
using namespace std; int a[111] ;
int num[11111] ;
int main() { int n ;
cin >> n ;
int ans = 0 ;
for (int i = 1 ; i <= n ;i ++ ){
cin >> a[i] ;
num[i] = num[i - 1] + a[i] ;
}
ans = num[n] - 1 ;
for(int i = 1; i <= n; ++i ){
for(int j = 1; j <= i; ++ j){
int sum = num[n] - 2 * ( num[i] - num[j-1] ) + ( i - j + 1 );
ans = max(sum ,ans) ;
}
}
cout << ans << endl; return 0 ;
}

B,直接打个素数表,然后输出前N个素数就可以了。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cmath>
#include <cstring>
#include <queue>
#include <set>
#include <vector>
#include <stack>
#include <map>
#include <iomanip>
#define PI acos(-1.0)
#define Max 2505
#define inf 1<<28
#define LL(x) ( x << 1 )
#define RR(x) ( x << 1 | 1 )
#define REP(i,s,t) for( int i = ( s ) ; i <= ( t ) ; ++ i )
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define mp(a,b) make_pair(a,b)
#define PII pair<int,int>
using namespace std; bool flag[11111111] ;
void prime(){
flag[0] = 1 ;
flag[1] = 1 ;
flag[2] = 0 ;
for (int i = 2 ;i <= 1300000 ; i ++ ){
if(!flag[i]){
for (int j = 2 * i ;j <= 1300000 ;j += i){
flag[j] = 1 ;
}
}
}
}
int a[111] ;
int num[1111111] ;
int main() {
prime() ;
int nn = 0 ;
for (int i = 2 ;i <= 1300000 ;i ++ ){
if(!flag[i])num[nn ++ ] = i ;
}
int n ;
cin >> n ;
cout << num[0] ;
for (int i = 1 ;i < n ;i ++ ){
printf(" %d",num[i]) ;
}
cout << endl;
return 0 ;
}

C,可以推出,k个连续的字符串是满足等比数列的关系的。

所以我们只需求出a1 和比例q就可以了。

首相就是只有一个字符串的时候,所有的删除的总和。

q就是pow(2 , l),l是字符串的长度。

等比数列求和公式 (a1 * (q ^ n - 1)) / (q - 1)%MOD 。先将a1 拿到外面去,不参与计算。我们设q ^ n - 1为a ,q - 1 为b 。那么式子就变成a / b %MOD 。这就变成很熟悉的拓展欧几里德了,先求出b % MOD的逆元x . x * b % MOD  = 1 ,那么 (a / b ) %MOD * (x * b) % MOD 的值不变,那么可以将式子化简成(a * x) % MOD 。

最后再将a1乘上即可。

#define MOD 1000000007

char a[111111] ;

inline ll extend_gcd(ll a ,ll b , ll& x , ll& y){
ll ans , t ;
if(b == 0){
x = 1 ;
y = 0 ;
return a ;
}
ans = extend_gcd(b , a % b ,x ,y ) ;
t = x ;
x = y ;
y = t - (a / b) * y ;
return ans ;
} ll quick_pow(ll a ,ll b , ll M){
ll ret = 1 ;
ll temp = a ;
while(b){
if(b & 1){
ret = (ret * temp) % M ;
}
temp = (temp * temp) % M ;
b >>= 1 ;
}
return ret ;
}
int main(){
cin >> a ;
int k ;
cin >> k ;
int l = strlen(a) ;
ll a1 = 0 ;
REP(i , 0 ,l - 1 ){
if(a[i] == '0' || a[i] == '5'){
a1 = (a1 + quick_pow(2 ,i ,MOD)) % MOD ;
}
}
ll a = quick_pow(2 , l ,MOD) ;
ll aa = (a - 1 + MOD) % MOD ;
ll x , y ;
extend_gcd(aa ,MOD , x ,y) ;
x = (x + MOD) % MOD ;
ll c = (quick_pow(a , k ,MOD) - 1) * x % MOD ;
ll ans = c * a1 % MOD ;
cout << ans << endl;
return 0 ;
}

D,DFS,每次进入一个空地,先将他建成蓝色的,然后向四个方向DFS,最后回溯的时候将这个蓝色的建筑拆掉建成红色的,当然第一个进入的点是不能建成红色的。

这个很容易证明,一个联通块里面,肯定有一个是蓝色的,其他都是红色的。

int n , m ;
char op[11111111] ;
int xx[11111111] ;
int yy[11111111] ;
int ss[555][555] ;
char Map[555][555] ;
int num = 0 ;
void dfs(int x ,int y ,int first ) {
if(x < 1 || x > n || y < 1 || y > m)return ;
op[num] = 'B' ;
xx[num] = x ;
yy[num] = y ;
num ++ ;
ss[x][y] = 0 ;
if(ss[x - 1][y])dfs(x - 1 ,y , 1) ;
if(ss[x][y - 1])dfs(x ,y - 1 ,1 ) ;
if(ss[x + 1][y])dfs(x + 1 ,y , 1) ;
if(ss[x][y + 1])dfs(x ,y + 1 ,1 ) ;
if(first) {
op[num] = 'D' ;
xx[num] = x ;
yy[num] = y ;
num ++ ;
op[num] = 'R' ;
xx[num] = x ;
yy[num] = y ;
num ++ ;
}
}
int main() {
cin >> n >> m ;
for (int i = 1 ; i <= n ; i ++ ) {
for (int j = 1 ; j <= m ; j ++ ) {
cin >> Map[i][j] ;
if(Map[i][j] == '.') {
ss[i][j] = 1 ;
}
}
}
for (int i = 1 ; i <= n ; i ++ ) {
for (int j = 1 ; j <= m ; j ++ ) {
if(ss[i][j]) {
dfs(i ,j , 0 ) ;
}
}
}
cout << num << endl;
for (int i = 0 ; i < num ; i ++ ) {
cout << op[i] << " " << xx[i] << " " << yy[i] << endl;
}
return 0 ;
}

E。状态压缩DP。

枚举1<< 24的状态。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
#include <cmath>
#include <cstring>
#include <queue>
#include <set>
#include <vector>
#include <stack>
#include <map>
#include <iomanip>
#define PI acos(-1.0)
#define Max 2505
#define inf 1<<28
#define LL(x) ( x << 1 )
#define RR(x) ( x << 1 | 1 )
#define REP(i,s,t) for( int i = ( s ) ; i <= ( t ) ; ++ i )
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define mp(a,b) make_pair(a,b)
#define PII pair<int,int>
using namespace std; #define MOD 1000000007 inline void RD(int &ret) {
char c;
do {
c = getchar();
} while(c < '0' || c > '9') ;
ret = c - '0';
while((c=getchar()) >= '0' && c <= '9')
ret = ret * 10 + ( c - '0' );
} int a[111111] ;
int sum[1 << 24] ;
int dp[1 << 24] ;
int k[11] ; int main(){ int n ;
cin >> n ;
for (int i = 0 ;i < n ; i ++ ){
RD(a[i]) ;
} int m ;
cin >> m ;
for (int i = 0 ;i < m ;i ++ ){
RD(k[i]) ;
}
dp[0] = 1 ;
for (int i = 1 ;i < (1 << n) ; ++ i){//枚举当前路径
int pos ;
bool flag = 0 ;
sum[i] = 0 ;
for (int j = 0 ;j < n ;j ++ ){
if(i & (1 << j)){//i 在 j 这点为1 ,直接在这里找出sum[i]的值会T。O(2 ^ 24 * n)
pos = j ;//一开始我直接写sum[i] += a[j] ;就T了
break ;
}
}
sum[i] = sum[i ^ (1 << pos)] + a[pos] ;//i 状态的所有步数。
for (int j = 0 ; j < m ;j ++ ){//i状态的步数是否不能走。
if(sum[i] == k[j]){
dp[i] = 0 ;
flag = 1 ;
break ;
}
}
if(flag)continue ;
dp[i] = 0 ;
for (int j = 0 ;j < n ;j ++ ){
if(i & (1 << j)){//i 这位可以由i ^ (1 << j )这一状态过来。
dp[i] = (dp[i] + dp[i ^ (1 << j)]) ;
if(dp[i] >= MOD)dp[i] -= MOD ;
}
}
} cout << dp[(1 << n) - 1] << endl;
return 0 ;
}

CF 191 div2的更多相关文章

  1. cf 442 div2 F&period; Ann and Books&lpar;莫队算法&rpar;

    cf 442 div2 F. Ann and Books(莫队算法) 题意: \(给出n和k,和a_i,sum_i表示前i个数的和,有q个查询[l,r]\) 每次查询区间\([l,r]内有多少对(i, ...

  2. CF&num;603 Div2

    差不多半年没打cf,还是一样的菜:不过也没什么,当时是激情,现在已是兴趣了,开心就好. A Sweet Problem 思维,公式推一下过了 B PIN Codes 队友字符串取余过了,结果今天早上一 ...

  3. CF R631 div2 1330 E Drazil Likes Heap

    LINK:Drazil Likes Heap 那天打CF的时候 开场A读不懂题 B码了30min才过(当时我怀疑B我写的过于繁琐了. C比B简单多了 随便yy了一个构造发现是对的.D也超级简单 dp了 ...

  4. CF&num;581 &lpar;div2&rpar;题解

    CF#581 题解 A BowWow and the Timetable 如果不是4幂次方直接看位数除以二向上取整,否则再减一 #include<iostream> #include&lt ...

  5. &lbrack;CF&num;286 Div2 D&rsqb;Mr&period; Kitayuta&&num;39&semi;s Technology(结论题)

    题目:http://codeforces.com/contest/505/problem/D 题目大意:就是给你一个n个点的图,然后你要在图中加入尽量少的有向边,满足所有要求(x,y),即从x可以走到 ...

  6. CF 191 总结

    A. Flipping Game 链接:http://codeforces.com/contest/327/problem/A 题意:从 i 到 j 翻转一次使得 1 的 个数最多~ 直接暴力搞~ # ...

  7. CF 197 DIV2 Xenia and Bit Operations 线段树

    线段树!!1A 代码如下: #include<iostream> #include<cstdio> #define lson i<<1 #define rson i ...

  8. CF&num;345 div2 A&bsol;B&bsol;C题

    A题: 贪心水题,注意1,1这组数据,坑了不少人 #include <iostream> #include <cstring> using namespace std; int ...

  9. CF R303 div2 C&period; Woodcutters

    C. Woodcutters time limit per test 1 second memory limit per test 256 megabytes input standard input ...

随机推荐

  1. OAF&lowbar;开发系列02&lowbar;实现OAF页面的通过个性化多语言开发国际化(案例)

    2014-06-10 Created By BaoXinjian

  2. 修改sys密码与nbu备份脚本密码后,nbu备份报密码无效

    公司要求口令强化,在修改sys密码后nbu的.sh脚本connect备份归档的sys/passwd也随之修改修改后每个业务备份均失败, 每次备份到归档那里就结束报密码无效,疑惑备份脚本密码也同步修改了 ...

  3. 【转】本地存储-localStroage&sol;sessionStorage存储

    原文地址:[js学习笔记-103]----本地存储-localStroage/sessionStorage存储 客户端存储 l  WEB存储 web存储最初作为html5的一部分被定义成API形式,但 ...

  4. 电脑控制台灯&lpar;c&num; hook&comma;显示室温&comma;联网校正时间&rpar;

          突发奇想,于是便写了一个小程序用于控制台灯,这几天功能也在不断的完善中,目前基本已经完成.下面进行功能的简述的代码的分析. 整体设计包含下位机程序和上位机程序.下位机用的c语言,上位机用的 ...

  5. 在路由器 RT-AC68U 使用自定义 DDNS 用 3322&period;org 动态域名的方法

    0.使用华硕的第三方固件 -- 梅林固件 , 具体更新固件方法不在本主题述说 1.打开 jffs, 以便启动时可以自动执行脚本 2.在 /jffs/scripts 下新建 ddns-start 文件. ...

  6. CodeForces 483B Friends and Presents

     Friends and Presents Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I ...

  7. IOS文件存储小结

    转自:http://tyragain.lofter.com/post/84706_c1503 首选项设置存储 NSUserDefaults 以及通过它控制的SettingBundle  NSUserD ...

  8. 动态链接库中分配内存引起的问题-- windows已在XX&period;exe中触发一个断点

    动态链接库中分配内存引起的 本文主要是探讨关于在动态链接库分配的内存在主程序中释放所产生的问题,该问题是我在刚做的PJP工程中所遇到的,由于刚碰到之时感动比较诡异(这也是学识不够所致),所以将它写下来 ...

  9. Android: 在WebView中获取网页源码

    1. 使能javascript: ? 1 webView.getSettings().setJavaScriptEnabled(true); 2. 编写本地接口 ? 1 2 3 4 5 final c ...

  10. &period;Net业务搭配实用技术栈(转)

      前言 昨天有篇文章在讨论webform的设计思路,我已经四五年不用webform了,虽然它也提供了HttpModule和httphandle来处理请求,提供了一般处理程序ashx来简化处理流程,但 ...