合肥学院ACM集训队第一届暑假友谊赛 B FYZ的求婚之旅 D 计算机科学家 F 智慧码 题解...
比赛网址:https://ac.nowcoder.com/acm/contest/994#question
B FYZ的求婚之旅
思路:
然后用快速幂即可。
细节见代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define rt return
#define dll(x) scanf("%I64d",&x)
#define xll(x) printf("%I64d\n",x)
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl
using namespace std;
typedef long long ll;
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
ll powmod(ll a,ll b,ll MOD){ll ans=1;while(b){if(b%2)ans=ans*a%MOD;a=a*a%MOD;b/=2;}return ans;}
inline void getInt(int* p);
const int maxn=1000010;
const int inf=0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/int main()
{//freopen("D:\\common_text\\code_stream\\in.txt","r",stdin);//freopen("D:\\common_text\code_stream\\out.txt","w",stdout);const ll mod=1e9+7ll;ll n,m;cin>>n>>m;ll ans=powmod(m+1ll,n,mod);cout<<ans<<endl;return 0;
}inline void getInt(int* p) {char ch;do {ch = getchar();} while (ch == ' ' || ch == '\n');if (ch == '-') {*p = -(getchar() - '0');while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 - ch + '0';}}else {*p = ch - '0';while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 + ch - '0';}}
}
D 计算机科学家
思路:
19=16+2+1
而在二进制数后面加4个0,就等于这个数乘以16。
加一个0,就等于这个数乘以2
然后三个二进制字符串相加即可。
二进制字符串相加,只有3种状态,两个1,两个0,一个1和一个0。
枚举下情况就好了,维护一个进位状态。
细节见代码:
#include<bits/stdc++.h>
using namespace std;string add(string a,string b)
{int len1=a.size(),len2=b.size();if(len1>len2)swap(a,b),swap(len1,len2);reverse(a.begin(),a.end());reverse(b.begin(),b.end());for(int i=0;i<len2-len1;i++)a+="0";int f=0;string ans="";for(int i=0;i<len2;i++){int k=a[i]-'0'+b[i]-'0'+f;f=0;if(k>=2)k%=2,f=1;if(k==0)ans+="0";else ans+="1";}if(f)ans+="1";reverse(ans.begin(),ans.end());return ans;
}int main(){std::ios::sync_with_stdio(false);int n;cin>>n;string s;cin>>s;string s4=s+"0000",s2=s+"0";s=add(s,s4);s=add(s,s2);cout<<s<<endl;return 0;
}
F 智慧码
思路:
STL的基础应用。
用STL写很方便,
map来维护每一个数字对应的字符串信息,
用string类的自带函数来处理前导0。
细节见代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define rt return
#define dll(x) scanf("%I64d",&x)
#define xll(x) printf("%I64d\n",x)
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define chu(x) cout<<"["<<#x<<" "<<(x)<<"]"<<endl
using namespace std;
typedef long long ll;
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
ll powmod(ll a,ll b,ll MOD){ll ans=1;while(b){if(b%2)ans=ans*a%MOD;a=a*a%MOD;b/=2;}return ans;}
inline void getInt(int* p);
const int maxn=1000010;
const int inf=0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/map<int,string> m;
int n;
int a[maxn];
string rm0(string s){// 去除前导0函数int i;for(i=0;i<s.size()-1;i++)if(s[i]!='0')break;return s.substr(i);
}
int main()
{m[0]="0000";m[1]="0001";m[2]="0010";m[3]="0011";m[4]="0100";m[5]="0101";m[6]="0110";m[7]="0111";m[8]="1000";m[9]="1001";gbtb;cin>>n;string str;int x;repd(i,1,n){cin>>x;str="";int g=x%10;x/=10;int s=x%10;x/=10;int b=x%10;str=m[b]+m[s]+m[g];reverse(ALL(str));// 反转字符串cout<<rm0(str)<<endl;}return 0;
}inline void getInt(int* p) {char ch;do {ch = getchar();} while (ch == ' ' || ch == '\n');if (ch == '-') {*p = -(getchar() - '0');while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 - ch + '0';}}else {*p = ch - '0';while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 + ch - '0';}}
}
转载于:https://www.cnblogs.com/qieqiemin/p/11177625.html
合肥学院ACM集训队第一届暑假友谊赛 B FYZ的求婚之旅 D 计算机科学家 F 智慧码 题解...相关推荐
- ACM Sdut 2158 Hello World!(数学题,排序) (山东省ACM第一届省赛C题)
ACM Sdut 2158 Hello World!(数学题,排序) (山东省ACM第一届省赛C题) 题目描述 We know thatIvan gives Saya three problems t ...
- 浙江农林大学ACM集训队2019级队长退役回忆录(未实际退役版本)
前言 (今后肯定不会再刻意去训练,但是明年还是要回来发挥余热继续打比赛,因此现在的退役实际上是不完全的,在明年大四打完最后的赛季后会重新来补全这篇回忆录) 我还能清晰记得自己第一次来到集训队实验室的场 ...
- 东南大学2004年程序设计第一届初赛解题报告
东南大学2004年第一届逻辑算法大赛初赛解题报告 农夫三拳@seu ...
- 第一届大数据科学与工程国际会议最新、最热会议日程---中国贵阳 2016年5月25-26日...
大数据时代的悄然来临,正在深刻变革着人们的科研.生产.生活方式,推动社会经济的发展.相关领域技术的创新发展,甚至国家竞争力的提升.大数据已经成为全球关注的热点,成为国内外学术界.产业界普遍关注的热点研 ...
- 数博会重磅活动:第一届大数据科学与工程国际会议日程
大数据时代的悄然来临,正在深刻变革着人们的科研.生产.生活方式,推动社会经济的发展.相关领域技术的创新发展,甚至国家竞争力的提升.大数据已经成为全球关注的热点,成为国内外学术界.产业界普遍关注的热点研 ...
- 技能竞赛国赛_中西部第一!技能“川军”在第一届全国技能大赛斩获4金5银6铜...
12月13日,中华人民共和国第一届职业技能大赛在广东省广州市闭幕.红星新闻记者从四川省人社厅获悉,四川代表团共斩获4枚金牌.5枚银牌.6枚铜牌和36个优胜奖,39人成绩位居全国前十,34名选手将入围第 ...
- 2020 年第一届辽宁省大学生程序设计竞赛
2020 年第一届辽宁省大学生程序设计竞赛 A-组队分配 分析 代码 B-两点距离 分析 代码 C-轮到谁了? 分析 代码 F-最长回文串 分析 代码 G-管管的幸运数字 分析 代码 I-鸽子的整数运 ...
- 计算机技能大赛奖品,第一届全国技能大赛都有哪些奖励政策?
(来源:湖北人社) 原标题:第一届全国技能大赛都有哪些奖励政策? 中华人民共和国第一届职业技能大赛将于今年12月10日-13日在广州举行.本届大赛共设86个竞赛项目.其中,世赛选拔项目设63个竞赛项目 ...
- 2017第一届河北省大学生程序设计竞赛题解
超级密码 小明今年9岁了,最近迷上了设计密码!今天,他又设计了一套他认为很复杂的密码,并且称之为"超级密码". 说实话,这套所谓的"超级密码"其实并不难:对于一 ...
最新文章
- Spring、Spring Boot和TestNG测试指南 - @ActiveProfiles
- 5G NGC — 关键技术 — 网络切片 — 概述
- 《Visual C++ 开发从入门到精通》——1.4 技术解惑
- 自动增益控制AGC的simulink仿真
- iOS开发者工具功能详述
- 包含数字和指定字符的正则表达式_Excel公式练习39: 求字符串中的数字组成的数能够被指定数整除的数的个数...
- Unique Binary Search Trees
- request和response的中文乱码问题
- vector 函数都有哪些??
- *** cannot be resolved or is not a field
- 大橙子_【大橙子喜讯】工程学子斩获佳绩!——机械创新设计大赛
- python工资条教程_批量发工资怎么操作_利用python轻松解决用邮箱批量发工资条...
- WinRAR 5.60 官方简体中文无广告弹窗版本
- 如何能从自我怀疑中走出来?
- GB28181协议视频流媒体平台中国标设备编号和通道国标编号标记唯一的摄像头|视频|镜头通道
- 什么软件可以支持视频转换成文字?
- 将CAD图纸转换为黑白的PDF文件要怎么操作
- 80后,我们难忘的电视剧
- 学习分布式系统需要怎样的知识?
- 王慧文的光年之外离OpenAI还有多远?