Hihocoder [Offer收割]编程练习赛70 解题报告 By cellur925
并没有第四题。(还不会矩阵乘法加速线性数列)
题目1 : 数位翻转
描述
给定一个数 n,你可以进行若干次操作,每次操作可以翻转 n 的二进制表示下的某一位,即将 0 变成 1,1 变成 0
现在小 Hi 想知道,至少需要多少次操作,才能将 n 变成 n-1
输入
一个正整数 n
1 ≤ n ≤ 109
输出
输出最少的操作次数
签到题,模拟一下取出各位二进制数即可,极水,怒A。
#include<cstdio>
#include<algorithm> using namespace std; int n,m,lena,lenb,ans;
int a[],b[]; int main()
{
scanf("%d",&n);
m=n-;
while(n)
{
a[++lena]=n%;
n/=;
}
while(m)
{
b[++lenb]=m%;
m/=;
}
int len=max(lena,lenb);
for(int i=;i<=len;i++)
if(a[i]!=b[i]) ans++;
printf("%d",ans);
return ;
}
题目2 : 最短公共子序列
描述
给定一个 01 串 A,你需要找一个和它等长的01串 B,使得 A 和 B 的最长公共子序列最短
为了方便,你不需要输出 B,你只需要输出 A 和 B 的最长公共子序列的长度
输入
第一行一个 01 串 A
1 ≤ |A| ≤ 105
输出
输出最短的长度
- 样例输入
-
000111
- 样例输出
-
3
这个题啊,看起来有点唬人。一看到“最长公共子序列最短”,我上来就是一顿二分敲。后来发现check函数没法写,在固有的(我的)惯性思维中,把带字符串背景的都考虑成公共子串(中间不能有不同),而本题恰好反其道而行之,问子序列(子序列中间可间隔不同的)。
我们再冷静分析一下,状态要么是0,要么是1,手动模拟几组答案,可以发现答案正是A串中出现最少元素的个数。
抱着试试看的心态交了上去,竟然A了。qwq。
-
#include<cstdio>
#include<algorithm>
#include<cstring> using namespace std; char py[];
int c,d,ans;
int a[],b[]; int main()
{
scanf("%s",py+);
int len=strlen(py+);
for(int i=;i<=len;i++) a[i]=(int)py[i]-'';
for(int i=;i<=len;i++)
if(a[i]==) c++;else d++;
ans=min(c,d);
printf("%d",ans);
return ;
} -
题目3 : 拼三角形
时间限制:20000ms单点时限:1000ms内存限制:256MB描述
给定 n 根木棍,第 i 根长度为 ai
现在你想用他们拼成尽量多的面积大于 0 的三角形,要求每根木棍只能被用一次,且不能折断
请你求出最多能拼出几个
输入
第一行一个正整数 n
第二行 n 个正整数 a1 … an
1 ≤ n ≤ 15
1 ≤ ai ≤ 109
输出
输出最多能拼出几个三角形
学长表示:一道暴搜题!巧了!我就不会写暴搜!qwq!
再和学长学习一下qwq。
由于最多有15根棒,所以顶多也就5个三角形。
然后我们就搜就行了qwq。我的模拟&贪心只能拿75分。
注释写在码里qwq。
#include<cstdio>
#include<algorithm> using namespace std;
typedef long long ll; int n;
ll ans;
int a[];
bool flag[]; void dfs(int cnt,int a1,int a2,int pre)
{//cnt->当前已经选到第几个三角形
//a1->三角形中最短边,a2->三角形中最长边。
//pre->上一个选到哪了(下标)
if(cnt==ans+)
{
printf("%d",ans);
exit();//void函数中想直接return 0结束程序用exit
}
if(!a1)
{
for(int i=pre+;i<=n;i++)
{
if(flag[i]) continue;
flag[i]=;
dfs(cnt,a[i],,i);
flag[i]=;
}
}
else if(a1>&&a2<=)
{
for(int i=pre+;i<=n;i++)
{
if(flag[i]) continue;
flag[i]=;
dfs(cnt,a1,a[i],i);
flag[i]=;
}
}
else
{
for(int i=pre+;i<=n;i++)
{
if(flag[i]) continue;
if(a1+a2<=a[i]) return ;
flag[i]=;
dfs(cnt+,,,);
flag[i]=;
}
}
} int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%d",&a[i]);
sort(a+,a++n);
for(int i=n/;i>=;i--)
{
ans=i;//要几个 当前在哪 现在已经有几个边
dfs(,,,);
}
printf("%d",ans);
return ;
}
Hihocoder [Offer收割]编程练习赛70 解题报告 By cellur925的更多相关文章
- [Offer收割]编程练习赛13 解题报告
http://hihocoder.com/contest/offers13/problems 题目1 : 风格不统一如何写程序 首先:输入保证组成变量名的单词只包含小写字母. 做法:只要对不同的部分进 ...
- hihocoder [Offer收割]编程练习赛4
描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...
- hihocoder [Offer收割]编程练习赛61
[Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...
- ACM学习历程—Hihocoder [Offer收割]编程练习赛1
比赛链接:http://hihocoder.com/contest/hihointerview3/problem/1 大概有一个月没怎么打算法了.这一场的前一场BC,也打的不是很好.本来Div1的A和 ...
- hihocoder [Offer收割]编程练习赛14 小Hi和小Ho的礼物
题目1 : 小Hi和小Ho的礼物 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 某人有N袋金币,其中第i袋内金币的数量是Ai.现在他决定选出2袋金币送给小Hi,再选2袋 ...
- hihoCoder[Offer收割]编程练习赛1题目解析
题目1 : 九宫 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小Hi近期在教邻居家的小朋友小学奥数.而近期正好讲述到了三阶幻方这个部分,三阶幻方指的是将1~9不反 ...
- hihocoder offer收割编程练习赛8 C 数组分拆
思路:(引自bfsoyc的回答:http://hihocoder.com/discuss/question/4160) 动态规划.状态dp[i]表示 前i个数的合法的方案数,转移是 dp[i] = s ...
- hihocoder [Offer收割]编程练习赛18 C 最美和弦(dp)
题目链接:http://hihocoder.com/problemset/problem/1532 题解:一道基础的dp,设dp[i][j][k][l]表示处理到第几个数,当前是哪个和弦错了几次初始x ...
- hihoCoder [Offer收割]编程练习赛3 D子矩阵求和
子矩阵求和 http://hihocoder.com/discuss/question/3005 声明一下: n是和x一起的,m是和y一起的 x是横着的,y是纵着的,x往右为正,y往下为正 (非常反常 ...
随机推荐
- 洛谷——P1047 校门外的树
P1047 校门外的树 题目描述 某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米.我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置:数轴上的每个整数点,即0 ...
- MongoDB学习day04--NodeJs操作数据库增删改查
一.在Nodejs中使用Mongodb Nodejs需要引入的包 npm install mongodb --save -dev 或者使用镜像 cnpm install mongodb --save ...
- Java的发送邮件
以下内容引用自http://wiki.jikexueyuan.com/project/java/sending-email.html: 用Java应用程序来发送一封电子邮件是足够简单的,但是开始时应该 ...
- 核函数以及SVM相关知识(重点)
http://www.cnblogs.com/jerrylead/archive/2011/03/18/1988406.html http://blog.pluskid.org/?p=685 考虑我们 ...
- 当Eclipse爱上SVN
推荐使用:Subclipse :http://jingyan.baidu.com/article/1612d5007d41e9e20e1eeeff.html 为离线安装做准备: 1.下载Subver ...
- SQL 撤销索引、撤销表以及撤销数据库
SQL 撤销索引.撤销表以及撤销数据库 通过使用 DROP 语句,可以轻松地删除索引.表和数据库. DROP INDEX 语句 DROP INDEX 语句用于删除表中的索引. 用于 MS Access ...
- Intel为Google的物联网平台Brillo推出开发板Edison
Brillo* is a solution from Google* for building connected devices. Incorporating aspects of the Andr ...
- ubuntu下spring环境搭建
一.安装JDK 下载官网:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html 部署: ...
- api多版本方案(URL)
api多版本方案(URL) 1.利用url https://www.taofen8.com/api/v2/getXXX 2.利用自定义请求头 api-version https://www.taofe ...
- ExtJs中多个form情况下指定某个form使能
采用extjs的时候,如果一个页面存在多个,那么提交之时,究竟是哪个form使能,就要指明.我今天就遇到了这种情况:明明页面已经有提交,为啥没有提交到内容?一查才知道,我的页面是有2个form,我本意 ...