1.  召见骑士

【问题描述】

某王国有5位骑士,每位骑士都有自己的编号,且这个王国的编号都为奇数,分别为1,3,5,7,9,在国王召见他们之前他们都必须经过只能从一边进出的长廊,长廊的宽度只能坐一个人。2018年1月1日这天,所有骑士依照编号从小到大的次序提前在长廊的入口等待,且只有当前面的人进入长廊后,后面的人才能进入长廊。国王想要召见一些骑士,把他们的编号写在纸上,让侍卫去宣传召见,问国王写的召见编号是否合理?

【输入格式】

输入一个编号序列。

【输出格式】

如果合理,输出“YES”,如果不合理,输出“NO”。

【输入样例】

3 1 9 7 5

【输出样例】

YES

【输入样例】

5 1 3 7 9

【输出样例】

NO

#include <iostream>
using namespace std;
const int N = ;
int stack[N],a[N];
int top,n;
int main() {
for (int i = ; i <= ; ++ i) {
cin >> a[i];
}
top = ;
for (int i = ,cur = ; i <= ; i++) {
while (cur <= a[i]) {
stack[++top] = cur;
cur = cur+;
}
if (stack[top] == a[i]) {
--top;
} else {
cout << "NO" << endl;
return ;
}
}
cout << "YES" << endl;
return ;
}

2.  出栈顺序

【问题描述】

给定一个由n个元素构成的序列,你需要将其中的元素按顺序压入一个大小为c的栈并弹出。元素按它们的出栈顺序进行排列,会得到一个新的序列。我们知道,这样的序列会有很多种,请输出所有新序列中第一个元素最小的序列(若第一个元素最小的序列有多个,则令第二个尽可能小;若仍有多个,则令第三个最小,以此类推)。

【输入格式】

第一行,两个数n,c;

第二行n个数,为序列中n个元素的值。

【输出格式】

输出n个数,为满足要求的序列。

【样例输入】

6 3

5 2 3 8 7 4

【样例输出】

2 3 5 4 7 8

#include<iostream>
#include <climits>
using namespace std;
int n,c,flag,m;
int stack[],top;
int num[];
int main() {
int i,j;
cin >> n>> c;
for(i=; i<=n; i++)
cin >> num[i];
//6 3
//5 2 3 8 7 4
while(m<n) { // 变量m表示输出的数的个数
if(flag<n) { //flag表示栈内数字的个数
int minn=INT_MAX,q;
//根据栈的空余位置,找出数组的前几项(例如开始栈为空,空余3个位置那么我们就看数字前三位的最小值)
for(i=flag+; i<=flag+c-top && i<=n; i++) {
if(num[i]<minn) {
minn=num[i];
q=i;
}
}
//如果栈为空,我们直接把q项数据入栈
if(!top) {
for(i=flag+; i<q; i++) {
stack[++top]=num[i];
}
flag = q;
cout << num[flag]<<" "; //输出栈顶的最小值
m++;
} else { //如果栈不为空
//如果要入栈的数字比栈顶元素大,输出栈顶元素
if(stack[top]<num[q]) {
cout << stack[top--]<<" ";
m++;
} else { //如果要入栈数字比栈顶元素小,把该数字入栈
for(i=flag+; i<q; i++) {
stack[++top]=num[i];
}
flag = q;
cout << num[flag]<<" ";
m++;
}
}
} else { //如果满了,那么把栈里面的数据全部输出
while(top) {
cout << stack[top--]<<" ";
m++;
}
}
}
return ;
}

1.  回文素数

【问题描述】

一个数如果从左往右读和从右往左读数字是相同的,则称这个数是回文数,如121,1221,15651都是回文数。给定位数n,找出所有既是回文数又是素数的n位十进制数。(注:不考虑超过整型数范围的情况)。

输入:位数n,其中1<=n<=9。

输出:第一行输出满足条件的素数个数,第二行按照从小到大的顺序输出所有满足条件的素数,两个数之间用一个空格区分。

【样例输入1】

1

【样例输出1】

4

2 3 5 7

【样例输入2】

3

【样例输出2】

15

101 131 151 181 191 313 353 373 383 727 757 787 797 919 929

#include<iostream>
using namespace std;
int n;
long long a,b,res[],cnt;
//计算并返回10^x
long long mypow(int x) {
long long ans=;
for(int i=; i<=x; i++) {
ans=ans*;
}
return ans;
}
//关键是构造回文数 例如:n等于123,返回12321这样一个回文数
long long huiwen(long long x) {
long long ans=x;
x=x/;
while(x>) {
ans=ans*+x%;
x/=;
}
return ans;
}
//判断是否为素数
bool is_prime(long long x) {
for(long long i=; i*i<=x; i++) {
if(x%i==) {
return false;
}
}
return true;
}
int main() {
cin>>n;
if(n==) {
cout << << endl;
cout << "2 3 5 7" << endl;
} else if(n==) {
cout << << endl;
cout << << endl;
} else if(n%==) {
cout << << endl;
} else {
cnt=;
n=(n+)/;
//构造[a,b)区间内的回文数
a=mypow(n-);
b=mypow(n);
for(long long i=a; i<b; i++) {
long long t=huiwen(i);
if(is_prime(t)) {
res[cnt++]=t;
}
}
cout<<cnt<<endl;
for(int i=; i<cnt; i++) {
cout<<res[i]<<" ";
}
cout<<endl;
} }

2.  栈的操作

【问题描述】

现在有四个栈,其中前三个为空,第四个栈从栈顶到栈底分别为1,2,3,…,n。每一个栈只支持一种操作:弹出并压入。它指的是把其中一个栈A的栈顶元素x弹出,并马上压入任意一个栈B中。但是这样的操作必须符合一定的规则才能进行。规则1:A栈不能为空。规则2:B栈为空或x比B栈栈顶要小。

对于给定的n,请你求出把第四个栈的n个元素全部移到第一个栈的最少操作次数。

由于最少操作次数可能很多,请你把答案对2018取模。

【输入格式】

一行,一个n

【输出格式】

一行,一个正整数,为把最少操作次数mod 2018的值

【样例输入】

2

【样例输出】

3

#include<iostream>
#include<cstdio>
using namespace std;
const long long mod=;
long long n,ans;
int main() {
cin >> n;
long long to;
for(long long i=; i<=n; ++i) {
if((i+)*i>=*n) {
to=i-;
break;
}
}
//get to,求出几大块完整的相同项
long long last=;
for(long long i=; i<=to; ++i) {
long long it=i*last;
it%=mod;
ans+=it;
ans%=mod;
last*=;
last%=mod;
}
//累和
long long need=*n-to*to-to;
need/=;
//求出剩下项
ans+=*(need*last)%mod;
//取模
ans%=mod;
cout<<ans<<endl;
}
#include<iostream>
#include<cstdio>
using namespace std;
const long long mod=;
long long n,ans;
int main() {
cin >> n;
long long to;
for(long long i=; i<=n; ++i) {
if((i+)*i>=*n) {
to=i-;
break;
}
}
//get to,求出几大块完整的相同项
long long last=;
for(long long i=; i<=to; ++i) {
long long it=i*last;
it%=mod;
ans+=it;
ans%=mod;
last*=;
last%=mod;
}
//累和
long long need=*n-to*to-to;
need/=;
//求出剩下项
ans+=*(need*last)%mod;
//取模
ans%=mod;
cout<<ans<<endl;
}

3.  波兰表达式

【问题描述】

波兰表达式是一种把运算符前置的算术表达式,例如普通的表达式2 + 3的波兰表示法为+ 2 3。波兰表达式的优点是运算符之间不必有优先级关系,也不必用括号改变运算次序,例如(2 + 3) * 4的波兰表示法为* + 2 3 4。本题求解波兰表达式的值,其中运算符包括+ - * /四个。

【输入格式】

输入为一行,其中运算符和运算数之间都用空格分隔,运算数是浮点数。

【输出格式】

输出为一行,表达式的值。可直接用printf("%f\n", v)输出表达式的值v。

【样例输入】

* + 11.0 12.0 + 24.0 35.0

【样例输出】

1357.000000

提示:可使用atof(str)把字符串转换为一个double类型的浮点数。atof定义在math.h中

#include <iostream>
#include <cstring>
#include <math.h>
using namespace std;
int main() {
char str[][]= {};
int s=,i = ;
int a1,a2;
a1=a2=;
double a[]= {};
int p=;
while(cin>>str[s])
s++;
s--;
for(i=s; i>=; i--) {
if(strcmp(str[i],"+")==||strcmp(str[i],"-")==
||strcmp(str[i],"*")==||strcmp(str[i],"/")==) {
if(strcmp(str[i],"-")==) {
a[p-]=a[p]-a[p-];
a[p]=;
p--;
}
if(strcmp(str[i],"+")==) {
a[p-]=a[p]+a[p-];
a[p]=;
p--;
}
if(strcmp(str[i],"*")==) {
a[p-]=a[p]*a[p-];
a[p]=;
p--;
}
if(strcmp(str[i],"/")==) {
a[p-]=a[p]/a[p-];
a[p]=;
p--;
}
} else {
a[++p]=atof(str[i]);
}
}
printf("%f\n",a[]);
}

noip第17课作业的更多相关文章

  1. noip第33课作业

    1.    排座椅 [问题描述] 上课的时候总会有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情.不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有有限的D对同 ...

  2. noip第29课作业

    1.   钢条切割 [问题描述] 一家公司购买长钢条,将其切割成短钢条出售,切割本身没有成本,长度为i的短钢条的价格为Pi.那给定一段长度为n的钢条和一个价格表Pi,求钢条的切割方案使得收益Rn最大. ...

  3. noip第23课作业

    1.   营救 铁塔尼号遇险了!他发出了求救信号.距离最近的哥伦比亚号收到了讯息,时间就是生命,必须尽快赶到那里. 通过侦测,哥伦比亚号获取了一张海洋图.这张图将海洋部分分化成n*n个比较小的单位,其 ...

  4. noip第5课作业

    1.     计算税收 [问题描述] 对某产品征收税金,在产值1万元以上收税5%:在1万元以下但在5000元或者以上的征收税3%:在5000元以下但在1000元或以上征收税2%:1000元以下的免收税 ...

  5. noip第4课作业

    1.    计算邮资 [问题描述] 根据邮件的重量和用户是否选择加急计算邮费.计算规则:重量在1000克以内 (包含1000克),基本费8元.超过1000克的部分,每500克加收超重费4元,不足500 ...

  6. noip第11课作业

    1.    数字比较 定义一个函数check(n,d),让它返回一个布尔值,如果数字d在正整数n的某位中出现则返回true,否则返回false. 例如:check(325719,3)==true:ch ...

  7. noip第7课作业

    1.    求平均值 [问题描述] 在一次运动会方队表演中,学校安排了十名老师进行打分.对于给定的每个参赛班级的不同打分(百分制整数),按照去掉一个最高分.去掉一个最低分,再算出平均分的方法,得到改班 ...

  8. noip第17课资料

  9. noip第34课作业

    1.    信息加密 [问题描述] 在传递信息的过程中,为了加密,有时需要按一定规则将文本转换成密文发送出去.有一种加密规则是这样的:1. 对于字母字符,将其转换成其后的第3个字母.例如:A→D,a→ ...

随机推荐

  1. 转:css知多少(1)——我来问你来答

    1. 引言 各位前端或者伪前端(比如作者本人)的同志们,css对你们来说不是很陌生.比如我,在几年之前上大学的时候,给外面做网站就用css,而且必须用css.这样算下来也得六年多了,有些功能可能轻车熟 ...

  2. Liunx Pwd

    Linux中用 pwd 命令来查看”当前工作目录“的完整路径. 简单得说,每当你在终端进行操作时,你都会有一个当前工作目录. 在不太确定当前位置时,就会使用pwd来判定当前目录在文件系统内的确切位置. ...

  3. 抽象类,override,final和类模板

    抽象类: **有些函数由于信息不够具体,而无法实现** 由此而来的纯虚函数:在基类中声明的纯虚函数,在基类中无法实现(是因为在基类中定义的信息不够具体,不是学的知识不够),于是这个函数没办法规定具体的 ...

  4. (转)关于X64位系统IIS7下支持32位asp.net程序

    最近在windows2008 x64位系统下的IIS7下部署asp.net程序. vs2005或vs2008默认的情况下是Any cpu 的也就是支持x86和x64两种系统的.可我的程序在引用了一个三 ...

  5. iOS.Operation-on-ZipFile

    Operation on ZipFile Reference 在Mac OS X和iOS中操作.zip文件(例如创建zip文件, 从zip文件中抽取数据): 1. http://stackoverfl ...

  6. VS“当前上下文中不存在名称“ViewBag”,当前上下文不存在名称“model””-已解决

    自己的项目出现了错误提示,却能编译成功,但是有点强迫症,总是想解决这个错误. 上网找了一堆,都是删除缓存等一些方法,但是没有多大用处,我觉得还是版本号不对,没有引用进来相应的配置,所以配置下了Conf ...

  7. Selenium+PhantomJS

    Selenium Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,类型像我们玩游戏用的按键精灵,可以按指定的命令自动操作,不同是Selenium 可以直接运行在浏览器上, ...

  8. 如何修改隐藏Zblog/WordPress默认后台登录地址

    我相信很多博主站长都遇到过站点被暴力破解,虽然未被破解,但是经常收到那些尝试登录失败的邮件提醒也会心慌慌的.对于这种情况,最好的办法就是修改/隐藏我们的后台登录地址. 关于zblogASP后台登录地址 ...

  9. jsonp,ajax,json问题

    JSONP技术 JSONP是解决跨域问题的一种常见方式 跨域问题,因为浏览器有同源策略,所以当不同域间进行数据交互的时候就会出现跨域问题 同源策略:只有在同协议.同域名.同端口的情况下才能进去数据交互 ...

  10. UI设计教程分享:电商网页页面设计常见表现手法

    1.手绘插画  场景.人物以及加上故事的创意绘画 会给人梦幻若隐若现的感觉,留下深刻的印象,适合做活动页面以及宣传自已的品牌 2.简约 颜色少于三色,背景以明度偏低的颜色为主,在信息大爆炸的时代,我们 ...