九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解)
吉大考研机试2011年题目:
题目一(jobdu1105:字符串的反码)、 http://ac.jobdu.com/problem.php?pid=1105
一个二进制数,将其每一位取反,称之为这个数的反码。以下我们定义一个字符的反码。假设这是一个小写字符,则它和字符'a’的距离与它的反码和字符'z’的距离同样;假设是一个大写字符,则它和字符'A’的距离与它的反码和字符'Z’的距离同样;假设不是上面两种情况,它的反码就是它自身。
比如:'a’的反码是'z’;'c’的反码是'x’;'W’的反码是'D’;'1’的反码还是'1’;'$'的反码还是'$'。一个字符串的反码定义为其全部字符的反码。我们的任务就是计算出给定字符串的反码。输入!结束。
题目分析:此题目是字符串模拟问题,至须要依据题意模拟就可以,对于大写和小写推断就可以
if(大写字符) s[i] = 'A' + 'Z' - s[i];
if(小写字符) s[i] = 'a' + 'z' - s[i];
AC代码:
#include<iostream>#include<string>#include<cctype>//调用库函数,读者能够自己写using
namespace std;int
main(){ string s; while(getline(cin,s)){//注意空格 if(s=="!")
break; for(inti=0;i<s.length();i++){ if(isupper(s[i])){//是大写字母 s[i]='A'+'Z'-s[i]; } if(islower(s[i])){//是小写字母 s[i]='a'+'z'-s[i]; } } cout<<s<<endl; } return0;}
题目二(jobdu1106:数字之和)、 http://ac.jobdu.com/problem.php?pid=1106
对于给定的正整数 n,计算其十进制形式下全部位置数字之和,并计算其平方的各位数字之和。
题目分析:把整数转化成字符串,逐个累加每一位数字,注意字符转化为整数仅仅须要减去‘0’,即减去‘0’的ASCII值
AC代码:
#include<iostream>#include<cstdio>#include<cstring>#include<cstdlib>using
namespace std;int
CountSum(char *s){ intsum=0,len=strlen(s); for(inti=0;i<len;i++){ sum+=(s[i]-'0'); } returnsum;}int
main(){ intn; while(scanf("%d",&n)!=EOF&&n){ chars0[20],s1[20]; sprintf(s0,"%d",n);//itoa(n,s0,10);写入字符串 sprintf(s1,"%d",n*n); printf("%d %d\n",CountSum(s0),CountSum(s1)); //cout<<CountSum(s0)<<" "<<CountSum(s0)<<endl; } return0;}题目三(jobdu1107:搬水果)、 http://ac.jobdu.com/problem.php?pid=1107
小明能够把两堆水果合并到一起,消耗的体力等于两堆水果的重量之和。当然经过 n‐1 次合并之后,就变成一堆了。小明在合并水果时总共消耗的体力等于每次合并所耗体力之和。你的任务是设计出合并的次序方案,使小明耗费的体力最少,并输出这个最小的体力耗费值。比如有 3 种水果,数目依次为 1,2,9。能够先将 1,2 堆合并,新堆数目为3,耗费体力为 3。然后将新堆与原先的第三堆合并得到新的堆,耗费体力为 12。所以小明总共耗费体力=3+12=15,能够证明 15 为最小的体力耗费值。
题目分析:
此题在考优先队列,只是也不用自己写,STL里面有优先队列priority_queue
AC代码:
/** *优先队列问题 */#include<iostream>#include<queue>#include<algorithm>using
namespace std;int
main(){ //数据越小优先级越高,当中第二个參数为容器类型,第二个參数为比較函数。 intn; while(cin>>n&&n){ priority_queue<int, vector<int>,
greater<int> > q; inta,b; for(inti=0;i<n;i++){ cin>>a; q.push(a); } ints=0; while(q.size()>1){ a=q.top(); q.pop(); b=q.top(); q.pop(); s+=a+b; q.push(a+b); } cout<<s<<endl; } return0;}题目四(jobdu1108:堆栈的使用)、 http://ac.jobdu.com/problem.php?pid=1108
依据给定的字符,模拟栈的操作。每行的第一个字符可能是'P’或者'O’或者'A’;假设是'P’,后面还会跟着一个整数,表示把这个数据压入堆栈;假设是'O’,表示将栈顶的值 pop 出来,假设堆栈中没有元素时,忽略本次操作;假设是'A’,表示询问当前栈顶的值,假设当时栈为空,则输出'E'。堆栈開始为空。
题目分析:仅仅须要把各个字符与栈的操作相相应就可以。
AC代码:
#include<iostream>#include<stack>using
namespace std;int
main(){ intn; while(cin>>n&&n){ charc; int
a; stack<int> sta; for(inti=0;i<n;i++){ cin>>c; switch(c){ case'P': cin>>a; sta.push(a); break; case'O': if(!sta.empty()){//非空输出 sta.pop(); } break; case'A': if(!sta.empty()){//非空输出 cout<<sta.top()<<endl; } elsecout<<"E"<<endl; break; default:
break; } } cout<<endl; } return0;}题目五(jobdu1109:连通图)、
给定一个无向图和当中的全部边,推断这个图是否全部顶点都是连通的。
题目分析:简单的dfs()+标记搜索
AC代码:
/** *深度优先遍历+訪问标记 */#include<iostream>#include<cstring>using
namespace std;int
m,n,a[1001][1001];//记录边,a[i][j]=1;表示联通int
vis[1001];//记录定点是否被訪问int
dfs(int i){ vis[i]=1;//先做标记,已訪问 for(intj=1;j<=n;j++){//模拟推断全部边点 if(a[i][j]==1&&vis[j]==0)//能联通,且未訪问 dfs(j); }}int
main(){ intb,c; while(cin>>n>>m&&n){ memset(a,0,sizeof(a)); memset(vis,0,sizeof(vis)); for(inti=0;i<m;i++){ cin>>b>>c; a[b][c]=a[c][b]=1;//无向图 } dfs(1);//从第一个节点開始,原则上能够从随意结点開始 intok=1; for(inti=1;i<=n;i++){ if(vis[i]==0){//不联通 ok=0;
break; } } if(ok) cout<<"YES"<<endl; elsecout<<"NO"<<endl; } return0;}九度oj题目&吉大考研11年机试题全解的更多相关文章
- 九度oj题目&吉大考研10年机试题全解
吉大考研机试2010年题目 题目一(jobdu1478:三角形的边). http://ac.jobdu.com/problem.php?pid=1478 给出三个正整数,计算最小的数加上次小的数 ...
- 九度oj 题目1190:大整数排序
题目1190:大整数排序 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:4142 解决:1867 题目描述: 对N个长度最长可达到1000的数进行排序. 输入: 输入第一行为一个整数N,( ...
- 九度oj 题目1125:大整数的因子
题目描述: 已知正整数k满足2<=k<=9,现给出长度最大为30位的十进制非负整数c,求所有能整除c的k. 输入: 若干个非负整数c,c的位数<=30每行一个c,当c=-1时中止 ( ...
- 九度oj 题目1262:Sequence Construction puzzles(I)_构造全递增序列
题目描述: 给定一个整数序列,请问如何去掉最少的元素使得原序列变成一个全递增的序列. 输入: 输入的第一行包括一个整数N(1<=N<=10000). 接下来的一行是N个满足题目描述条件的整 ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
随机推荐
- 一切从编辑器说起:web前端代码编辑器
俗话说:工欲善其事,必先利其器. 工欲善其事必先利其器.谓工匠想要使他的工作做好,一定要先让工具锋利.比喻要做好一件事,准备工作非常重要. 前端写代码也是一样,需要一个好的适合自己的代码编辑器. 我想 ...
- 更改IOS于UISearchBar撤消button底、搜索输入文本框背景中的内容和UISearchBar底
转载请标明出处:http://blog.csdn.net/android_ls/article/details/39993433 測试的手机IOS系统版本为:6.1.3,实现过程例如以下: 1.加入U ...
- RH133读书笔记(10)-Lab 10 Exploring Virtualization
Lab 10 Exploring Virtualization Goal: To explore the Xen virtualization environment and the creation ...
- android中怎么把自己须要的app启动图标集中到一个弹出框中
先看效果图 这个是我们自己的apk点击之后的效果 下边是布局文件 activity_main.xml主布局文件 <LinearLayout xmlns:android="http:// ...
- 【剑指offer】打印1到最大的n数字
转载请注明出处:http://blog.csdn.net/ns_code/article/details/25562105 剑指offer第12题.九度OJ測试通过. 题目描写叙述: 给定一个数字N, ...
- 7.oracle学习门户系列七---网络管理和配置
oracle学习门户系列七 网络管理和配置 们学习了模式和用户.包含模式定义以及模式的作用. 这篇我么来看下ORACLE数据库中的网络管理和配置.只是这篇好像和上篇没有继承啊.这怎么看? Ok,事实上 ...
- sql 学习笔记 档
从下面的内容 3c school 1:Sql 它分为两部分: 6 2:查询 7 3:插入: 9 4:数据库更新 UPDATE 9 5:删除 DELETE 10 6:Sql TOP 子句: 10 7 ...
- hibernate 双向n-n
领域模型: 关系数据模型 双向 n-n 关联须要两端都使用集合属性 双向n-n关联必须使用连接表 集合属性应添加 key 子元素用以映射外键列, 集合元素里还应添加many-to-many子元素关联实 ...
- Python 相机镜头
一哥第一卷感叹,这家奥地利~.这是什么g8事件,近盲目安装3g的OpenCV,结果徒劳. . . 入题.!环境Python2.7 严厉格按照什么步骤.必成功: 所需的软件如下面: VideoCaptu ...
- GMSK调制仿真
GMSK 调制的的原理非常简单. 就是MSK调制前进行Gauss滤波. 在实现中有这样的方法,首先产生高斯系数,对称的上升陂和下降陂系数.输入一个符号,进行上采样,经过高斯滤波器,滤波器的输出做有符号 ...