4.9cf自训9..
cf401D 状态压缩dp好题,每次把新加入集合的数字放在最后即可
/*
它可以通过重新排列数字n,
它没有任何前导零,
x除以m后的余数等于0. 每次把新加的数放在最后
dp[i][j]表示状态i下模m=j的数量
dp[i|(1<<k)][j*10+a[k]]+=dp[i][j]; */
#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll len,n,m,a[];
ll dp[<<][];
int main(){
cin>>n>>m;
while(n)a[++len]=n%,n/=;
dp[][]=;
for(int i=;i<(<<len)-;i++)
for(int j=;j<m;j++)
for(int k=;k<len;k++){
if(i&(<<k))continue;
if(i==&&a[k+]==)continue;//前导0
dp[i|(<<k)][(j*+a[k+])%m]+=dp[i][j];
}
ll cnt[]={},f[]={},ans=dp[(<<len)-][];
f[]=f[]=;
for(int i=;i<=;i++)f[i]=f[i-]*i;
for(int i=;i<=len;i++)cnt[a[i]]++;
for(int i=;i<;i++)
if(cnt[i])ans/=f[cnt[i]];
cout<<ans<<endl;
}
cf959E 思维题
#include<bits/stdc++.h>
using namespace std;
#define ll long long
ll n,ans;
ll lowbit(ll x){return x&(-x);} int main(){
cin>>n;
ll tmp=n,cnt=;
while(tmp){
ans+=tmp/*cnt;
tmp/=,cnt*=;
}
if(n==lowbit(n)){
cout<<ans<<endl;
return ;
}
while(n){
n-=lowbit(n); ans+=lowbit(n);
}
cout<<ans<<endl;return ;
}
cf598E dp好题,就是最经典的线性dp,想通了挺简单的
/*
dp[i][j][k]在i*j的方块里吃k大小的代价
*/
#include<bits/stdc++.h>
using namespace std;
int dp[][][];
int main(){
for(int i=;i<=;i++)
for(int j=;j<=;j++)
for(int k=;k<=;k++){
if(k== || k==i*j){
dp[i][j][k]=;
continue;
}
else dp[i][j][k]=;
for (int h = ; h <= k; h++){
for (int m = ; m < j; m++)
dp[i][j][k] = min(dp[i][j][k], dp[i][m][h] + dp[i][j - m][k - h] + i*i);
for (int m = ; m < i; m++)
dp[i][j][k] = min(dp[i][j][k], dp[m][j][h] + dp[i - m][j][k - h] + j*j);
}
}
int t,n,m,k;
cin>>t;
while(t--){
cin>>n>>m>>k;
cout<<dp[n][m][k]<<endl;
}
}
cf886D 字符串乱搞+判环
#include<iostream>
#include<algorithm>
#include<string>
#include<string.h>
using namespace std; string s,ans[]; int main()
{
int i,j,n,f,x,len;
int vis[],chu[],ru[],mp[][];
while(cin>>n)
{
f=;
memset(mp,,sizeof(mp)); //字符构成的图
memset(ru,-,sizeof(ru)); //每个字符的入度
memset(chu,-,sizeof(chu)); //每个字符的出度
//在下面这个循环中,chu/ru=0则说明字符出现过,chu/ru=-1则没出现过
for(i=;i<n;i++)
{
cin>>s; //输入字符串
memset(vis,,sizeof(vis)); //用于判断每个字符串中字符出现的次数
len=s.length();
vis[s[]-'a']++; //首个字符出现次数+1
ru[s[]-'a']=; //首个字符出现过
chu[s[]-'a']=; //首个字符出现过
for(j=;j<len;j++)
{ //从第 1 个字符开始建图
int u=s[j-]-'a'; //前一字符
int v=s[j]-'a'; //当前字符
mp[u][v]=;
vis[v]++;
if(vis[v]>) f=; //如果出现次数>1,则输出 NO
ru[v]=;
chu[v]=;
}
}
int next[]; //每个字符的后继字符
memset(next,-,sizeof(next));
for(i=;i<;i++)
for(j=;j<;j++)
if(mp[i][j])
{ //如果存在边
ru[j]++; //入度+1
chu[i]++; //出度+1
next[i]=j; //记录后继
}
for(i=;i<;i++)
if(ru[i]>||chu[i]>)
{ //如果有字符的出度或入度 >1则输出 NO
f=;
break;
}
for(i=;i<;i++)
{ //判断是否有环
x=i;
memset(vis,,sizeof(vis));
while(x!=next[x])
{
if(vis[x]==)
{ //如果当前元素访问过则有环
f=;
break;
}
vis[x]=;
x=next[x];
}
}
if(n> || !f)
{
cout<<"NO"<<endl;
continue;
}
int tol=;
for(i=;i<;i++) //遍历 26个字符
if(ru[i]==)
{ //如果入度为 0,则会形成一串字符
ans[tol]='a'+i;
x=i;
while(next[x]!=-)
{ //加入后继字符
char c=next[x]+'a';
ans[tol]+=c;
x=next[x];
}
tol++;
}
sort(ans,ans+tol); //排序
for(i=;i<tol;i++) cout<<ans[i];
cout<<endl;
}
return ;
}
4.9cf自训9..的更多相关文章
- Java企业实训 - 01 - Java前奏
前言: 虽然个人专攻.NET方向,不过由于个人是干教育行业的,方方面面的东西,不能说都必须精通,但肯定多少都会涉及到. 一个菜鸟学员,从啥都不会,经过一步步学习,最后到企业上手掌管一个模块甚至一个项目 ...
- UML基础与Rose建模实训教程
目 录 第1章 初识UML. 1 1.1 初识UML用例图... 1 1.2 初识UML类图... 3 第2章 Rational Rose工具... 6 2.1 安装与配置Rational Ro ...
- <实训|第六天>偷偷让新手的Linux无限重启附linux主机名称不是随便乱改的!
先说个事情:这几天我正在忙一个项目的设计,8月1号之前要弄出来,所以每天都要弄到很晚,可能更新就有点跟不上了,不过我如果有时间的话,我就更新,没时间的话,我会在8月1号之后统一更新出来,希望大家谅解! ...
- <实训|第五天>通过搭建NFS,FTP实现共享文件附Vim脚本游戏
先说个事情:我周末是不更新这个系列教程的,不过其他内容的会更新,我周末就整理这一周的各种内容到我的微信公众号中,提供给大家! 期待已久的linux运维.oracle"培训班"终于开 ...
- ThoughtWorks西邮暑期特训营 -- JavaScript在线笔试题
ThoughtWorks 公司在西邮正式开办的只教女生前端开发的女子卓越实验室已经几个月过去了,这次计划于暑期在西邮内部开展面向所有性别所有专业的前端培训. 具体官方安排请戳:ThoughtWorks ...
- 软件工程实训项目案例--Android移动应用开发
实训过程 角色分工 1.项目经理:负责项目的组织实施,制定项目计划,并进行跟踪管理 2.开发人员:对项目经理及项目负责 3.需求分析员:负责系统的需求获取和分析,并协助设计人员进行系统设计 4.系统设 ...
- <实训|第四天>Linux下的vim你真的掌握了吗?附上ftp远程命令上传。
期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...
- <实训|第三天>Linux登录界面的修改以及Richard Stallman、自由软件运动
在写博客之前我想说两点: 承认一个错误,昨天写的实训第二天,我把redhat6.7写成了Linux6.7,感谢热心人士的指出! 昨天写的文章名字太长了,今天改善,内容感觉表述不全,希望各位谅解! 官方 ...
- <实训|第二天>掌握linux6.7中安装vmware、vmware安装linux发行版本以及遇到的问题最后libreoffice的安装
期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...
随机推荐
- 其它综合-CentOS7 忘记root密码
CentOS7 忘记root密码 长时间不用的 CentOS 机器再次开机的时候忽然忘记了密码,总不能就重装一台吧,还有好多服务在机器上,于是决定重置root的密码. 如果是已经开启的机器,需要进行关 ...
- 其它综合-使用Putty远程连接管理Linux实践
使用Putty远程连接管理Linux实践 1.获取putty 获取 putty有很多方法,以下是我为大家提供的下载地址: 个人网盘地址,提取码:tz83 官方下载地址 解释: 官方下载的是 zip 压 ...
- ASUS RT-AC68U 刷梅林固件及安装***插件记录(详细)
本文借鉴网络并亲自刷机过程记录(网上很多教程都不太详细) 版本:华硕ASUS RT- AC68U Wireless-AC1900 路由器的连接方式略,有说明书 连好后打开浏览器输入:http:/ ...
- Linux 学习 (三) 文件搜索命令
Linux达人养成计划 I 学习笔记 locate 文件名 搜索速度比较快 只能根据文件名搜索 搜索的是保存在 /var/lib/mlocate 的数据库(每天更新一次) 新建文件需要执行 updat ...
- 倍增\ tarjan求lca
对于每个节点v,记录anc[v][k],表示从它向上走2k步后到达的节点(如果越过了根节点,那么anc[v][k]就是根节点). dfs函数对树进行的dfs,先求出anc[v][0],再利用anc[v ...
- LOJ #2731. 「JOISC 2016 Day 1」棋盘游戏(dp)
题意 JOI 君有一个棋盘,棋盘上有 \(N\) 行 \(3\) 列 的格子.JOI 君有若干棋子,并想用它们来玩一个游戏.初始状态棋盘上至少有一个棋子,也至少有一个空位. 游戏的目标是:在还没有放棋 ...
- MySQL的SQL_Mode修改小计
问题复现 今天突然发现MySQL服务器升级之后sql_mode变成宽松摸索了,危害如下: 临时解决 set global sql_mode='strict_trans_tables'(阿里服务器默认是 ...
- <二>企业级开源仓库nexus3实战应用–使用nexus3配置docker私有仓库
1,安装nexus3. 这个地方略了,安装部署可以参考:nexus3安装配置. 2,配置走起. 1,创建blob存储. 登陆之后,先创建一个用于存储镜像的空间. 定义一个name,下边的内容会自动补全 ...
- androidstudio上传代码到git上
1.首先通过git --bare init 在服务端创建好了一个git仓库:假设git仓库在服务端的地址为:/user/lyh/project/test.git 2.androidstudio上点击V ...
- Redis(REmote DIctionary Server)基础
Redis(REmote DIctionary Server)基础 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Redis是一个开放源代码(BSD许可)的内存数据结构存储,用作数 ...