A.ElectronicPetEasy

【题意】一个数st1开始,每次加p1,一共加t1次,另外一个数st2开始,每次加p2,一共加t2次,输入的数均小于1000,问这两个数有没有可能相等,有可能输出“Easy”,否则输出“Difficult”

【解释】显然列出两个循环即可,1000*1000也不会超时

const string dif="Difficult";
const string eas="Easy";
class ElectronicPetEasy
{
public:
string isDifficult(int st1, int p1, int t1, int st2, int p2, int t2)
{
int i,j,k;
int m1=st1+p1*(t1-1);
int m2=st2+p2*(t2-1);
for (i=st1;i<=m1;i+=p1)
{
for (j=st2;j<=m2;j+=p2)
{
if (i==j) return dif;
}
}
return eas;
}
};

B.AliceGameEasy

【题意】从1到n,爱丽丝取出几个数累加为x,桐人取出几个数累加为y,给出x和y,问爱丽丝做少取了多少个数(不可能时输出-1)。

【解释】贪心算法

先判断x+y=n*(n+1)/2,能否求出整数n,不能求出来 或者 求出的n不是整数 那么输出-1就好喽

既然求出n了,就让爱丽丝从最大的数开始取,n,n-1,n-2...直到存在k ,使得刚好n+(n-1)+(n-1)+...+(n-k+1)>=x("刚好"的意思是n+(n-1)+(n-1)+...+(n-k)<x),答案就是k。

class AliceGameEasy
{
public:
long long findMinimumValue(long long x, long long y)
{
LL i,j,k;
LL dt=(x+y)*8+1;
LL sqr_dt=(LL)(sqrt(dt));
if (sqr_dt*sqr_dt!=dt) return -1;
sqr_dt--;
if (sqr_dt%2) return -1;
LL n=sqr_dt/2;
LL ans=0;
while (x>0)
{
x-=n;
n--;
ans++;
}
return ans;
}
};

C.BoardFoldingDiv2

【题意】给出一个01矩阵(最多50*50)(就是题目说的纸),现在要折叠这个矩阵,折叠要满足:

1.平行于某条边折叠

2.要沿相邻两列数字之间折叠

3.折叠后下方的数字与上方的数字相等

现在问有多少种折叠方法,(其中折叠后如果是同一块矩阵区间则算同一种方法)

【解释】显然是可以将行与列分开求,求只按行折叠的方法数ansr,和只按列折叠的方法数ansc,最后ansr*ansc就是答案。

由于按行和按列求的方法相同,下面以按列举例。

出题人相当良心,只给了50*50的规模,而且最重要的是只有0和1,那么将每列的01串视为一个二进制数,用long long存完全能存下,我们存到c[]数组中。

大致思路:枚举右界,如果右界可行的话(需要预处理),再枚举左界,如果左界也可行的话,就算是一个解。

这是预处理:设right[i]=1表示从右开始折叠,能折叠到i,即折叠后第i+1~n-1个数(数的编号是0到n-1)全都消失掉了。当然right[i]=0时表示不能折叠到第i个数。

然后枚举左界,right[k]=1时,枚举左界i,用left[i]表示从左开始折叠,能折叠到i(与right[]是相同的思路,只是变了一下方向)。

算法是O(n3)的

typedef long long LL;
int n,m;
LL r[55],c[55];
int ansr,ansc,lef[55],rig[55];
class BoardFoldingDiv2
{
public: int howMany(vector <string> paper)
{
int i,j,k;
memset(r,0,sizeof(r));
memset(c,0,sizeof(c));
ansr=ansc=0;
n=paper.size();
m=paper[0].size(); for (i=0;i<n;i++)
{
for (j=0;j<m;j++)
{
r[i]=r[i]*2+paper[i][j]-'0';
c[j]=c[j]*2+paper[i][j]-'0';
}
}
/*对每一横行操作*/
memset(rig,0,sizeof(rig));
rig[n-1]=1;
for (i=n-2;i>=0;i--)
{
for (j=1;i+j<n&&i-j+1>=0;j++)
{
if (r[i+j]==r[i-j+1])
{
if (rig[i+j])
{
rig[i]=1;
break;
}
}
else break;
}
}
for (k=n-1;k>=0;k--)//枚举右界
{
if (rig[k]==0) continue;//如果右界不可达,continue
memset(lef,0,sizeof(lef));
lef[0]=1; ansr++;
for (i=1;i<=k;i++)//枚举左界
{
for (j=1;i+j-1<=k&&i-j>=0;j++)//判断左界是否可达
{
if (r[i+j-1]==r[i-j])
{
if (lef[i-j])//如果left[i-j]可达 并且 正好能沿数i与数i-1间折叠
{
lef[i]=1;//设为可达后跳出
break;
}
}
else break;
}
if (lef[i]!=0) ansr++;
}
} /*对每一列操作*/
memset(rig,0,sizeof(rig));
rig[m-1]=1;
for (i=m-2;i>=0;i--)
{
for (j=1;i+j<m&&i-j+1>=0;j++)
{
if (c[i+j]==c[i-j+1])
{
if (rig[i+j])
{
rig[i]=1;
break;
}
}
else break;
}
} for (k=m-1;k>=0;k--)
{
if (rig[k]==0) continue;
memset(lef,0,sizeof(lef));
lef[0]=1; ansc+=min(1,lef[0]*rig[k]);
for (i=1;i<=k;i++)
{
for (j=1;i+j-1<=k&&i-j>=0;j++)
{
if (c[i+j-1]==c[i-j])
{
if (lef[i-j])
{
lef[i]=1;
break;
}
}
else break;
}
if (lef[i]!=0) ansc++;
}
}
return ansr*ansc;
}
};

Topcoder SRM 639 (Div.2)的更多相关文章

  1. TopCoder SRM 639 Div.2 500 AliceGameEasy

    题意: 一个游戏有n轮,有A和B比赛,谁在第 i 轮得胜,就获得 i 分,给出x,y,问A得x分,B得y分有没有可能,如果有,输出A最少赢的盘数 解题思路: 首先判断n(n+1)/2 = (x+y)是 ...

  2. TopCoder SRM 639 Div.2 500 AliceGameEasy --乱搞

    题意: 一个游戏有n轮,有A和B比赛,谁在第 i 轮得胜,就获得 i 分,给出x,y,问A得x分,B得y分有没有可能,如果有,输出A最少赢的盘数. 解法: 这题是我傻逼了,处理上各种不优越,要使n*( ...

  3. TopCoder SRM 560 Div 1 - Problem 1000 BoundedOptimization & Codeforces 839 E

    传送门:https://284914869.github.io/AEoj/560.html 题目简述: 定义"项"为两个不同变量相乘. 求一个由多个不同"项"相 ...

  4. TopCoder SRM 667 Div.2题解

    概览: T1 枚举 T2 状压DP T3 DP TopCoder SRM 667 Div.2 T1 解题思路 由于数据范围很小,所以直接枚举所有点,判断是否可行.时间复杂度O(δX × δY),空间复 ...

  5. [topcoder]SRM 646 DIV 2

    第一题:K等于1或者2,非常简单.略.K更多的情况,http://www.cnblogs.com/lautsie/p/4242975.html,值得思考. 第二题:http://www.cnblogs ...

  6. [topcoder]SRM 633 DIV 2

    第一题,http://community.topcoder.com/stat?c=problem_statement&pm=13462&rd=16076 模拟就可以了. #includ ...

  7. TopCoder SRM 596 DIV 1 250

    body { font-family: Monospaced; font-size: 12pt } pre { font-family: Monospaced; font-size: 12pt } P ...

  8. Topcoder SRM 656 (Div.1) 250 RandomPancakeStack - 概率+记忆化搜索

    最近连续三次TC爆零了,,,我的心好痛. 不知怎么想的,这题把题意理解成,第一次选择j,第二次选择i后,只能从1~i-1.i+1~j找,其实还可以从j+1~n中找,只要没有被选中过就行... [题意] ...

  9. Topcoder SRM 648 (div.2)

    第一次做TC全部通过,截图纪念一下. 终于蓝了一次,也是TC上第一次变成蓝名,下次就要做Div.1了,希望div1不要挂零..._(:зゝ∠)_ A. KitayutaMart2 万年不变的水题. # ...

随机推荐

  1. [LeetCode OJ] Linked List Cycle II—Given a linked list, return the node where the cycle begins. If there is no cycle, return null.

    /** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode ...

  2. java面试题及答案(基础题122道,代码题19道)

    JAVA相关基础知识 1.面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面.抽象并不打算了解全部问题,而只是选择其中的一部分, ...

  3. linux关机重启命令浅析

    linux关机重启命令 今天我们来介绍下linux系统中常用到的关机重启命令—shutdown.halt.reboot.poweroff以及init. shutdown命令 以安全的方式关闭系统或重启 ...

  4. 文件操作-php

    <?php /* 建立缓存 可以用文件长时间保存数据 文件是以liunux为模型的 在Windows下只能获取file ,dir unknow linux 下可以获取block char dir ...

  5. JavaScript-学习一字符串

    字符串可以存储一系列字符,如 "John Doe". 字符串可以是插入到引号中的任何字符.你可以使用单引号或双引号: 用于字符串的 + 运算符 + 运算符用于把文本值或字符串变量加 ...

  6. Spring4.0学习笔记(9) —— Spring泛型依赖注入

    1.定义基础仓库 package com.spring.generic.di; public class BaseRepository<T> { } 2.定义基础服务层 package c ...

  7. jQuery键盘控制方法,以及键值(keycode)对照表

    键盘控制应用范围非常广泛,比如快捷键控制页面的滚动:在填写表单时候,限制输入内容:或者是屏蔽复制.粘贴.退后等功能.这里说说用jQuery怎么来实现.个人觉得jQuery比原生态的JS好用,代码简单清 ...

  8. Day5 双层装饰器、字符串格式化、生成器、迭代器、递归

    双层装饰器实现用户登录和权限认证 #!/usr/bin/env python# -*- coding: utf-8 -*-# Author: WangHuafeng USER_INFO = {} de ...

  9. URL加载系统----iOS工程师必须熟练掌握

    URL加载系统----iOS工程师必须熟练掌握     iOS根本离不开网络——不论是从服务端读写数据.向系统分发计算任务,还是从云端加载图片.音频.视频等.   当应用程序面临处理问题的抉择时,通常 ...

  10. 多台web服务器之间共享session

    常见的几种方法如下: 1. 写客户端Cookie的方式 当用户登陆成功以后,把网站域名.用户名.密码.token.session有效时间全部采用cookie的形式写入到客户端的cookie里面,如果用 ...