没有合适的资源?快使用搜索试试~ 我知道了~
c++语言编程经典43例(带运行结果).pdf
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 187 浏览量
2022-01-05
12:27:39
上传
评论
收藏 7.18MB PDF 举报
温馨提示
试读
38页
c++语言编程经典43例(带运行结果).pdf
资源推荐
资源详情
资源评论
这些是我用半个月的时间整理的, 都是源自经典算法
100例,但是源文档有很多错误和不规范之处,下面的 43 例
中,都是经过 c++6.0 编译器通过的。仅供参考,如果有不
懂之处咱们共同探讨,我的邮箱:
www.dingxiaoyao2006@126.com
C++
语言编程经典 43 例
【程序 1】题目:有 1、2、3、4 个数字,能组成多少个互不相同且无重复数字的三位数?都
是多少?
1. 程序分析:可填在百位、十位、个位的数字都是 1、 2、3、4。组成所有的排列后再去掉
不满足条件的排列。
#include<iostream>
using namespace std;
int main()
{
int i,j,k;
for(i=1;i<5;i++){
for(j=1;j<5;j++)
{
for(k=1;k<5;k++)
{
if(i!=j&&i!=k&&j!=k)
cout<<i*100+j*10+k<<" ";
}
}
}
return 0;
};
运行结果: 123 124 132 134 142 143 213 214 231 234 241 243 312 314 321 324 341 342
412 413 421 423 431 432
==============================================================
【程序 2】题目:企业发放的奖金根据利润提成。利润 (I) 低于或等于 10 万元时,奖金可提
10%;利润高于 10 万元,低于 20 万元时,低于 10 万元的部分按 10%提成,高于 10 万元的
部分,可可提成 7.5%;20 万到 40 万之间时,高于 20 万元的部分,可提成 5%;40 万到 60
万之间时高于 40 万元的部分,可提成 3%;60 万到 100 万之间时,高于 60 万元的部分,可
提成 1.5%,高于 100 万元时,超过 100 万元的部分按 1%提成,从键盘输入当月利润 I ,求
应发放奖金总数?
1. 程序分析:请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。
#include<iostream>
using namespace std;
int main()
{
long int i;
int bonus1,bonus2,bonus4,bonus6,bonus10,bonus;
cin>>i;
bonus1=100000*0.1;bonus2=bonus1+100000*0.75;
bonus4=bonus2+200000*0.5;
bonus6=bonus4+200000*0.3;
bonus10=bonus6+400000*0.15;
if(i<=100000)
bonus=i*0.1;
else if(i<=200000)
bonus=bonus1+(i-100000)*0.075;
else if(i<=400000)
bonus=bonus2+(i-200000)*0.05;
else if(i<=600000)
bonus=bonus4+(i-400000)*0.03;
else if(i<=1000000)
bonus=bonus6+(i-600000)*0.015;
else
bonus=bonus10+(i-1000000)*0.01;
cout<<"bonus="<<bonus<<endl;
return 0;
};
运行结果: 3000
bonus=300
==============================================================
【程序 3】题目:一个整数,它加上 100 后是一个完全平方数,再加上 168 又是一个完全平
方数,请问该数是多少?
1. 程序分析: 在 10 万以内判断, 先将该数加上 100 后再开方, 再将该数加上 268 后再开方,
如果开方后的结果满足如下条件,即是结果。请看具体分析:
2. 程序源代码:
#include<iostream>
using namespace std;
#include<cmath>
int main()
{
long int i,x,y;
for (i=1;i<100000;i++)
{
x=sqrt(i+100);
//x 为加上 100 后开方后的结果
y=sqrt(i+268);
//y 为再加上 168 后开方后的结果
if(x*x==i+100&&y*y==i+268)
// 如果一个数的平方根的平方等于该数,这说明此数是完全平方数 */
cout<<i<<endl;
}
return 0;
}
运行结果: 21
261
1581
==============================================================
【程序 4】
题目:输入某年某月某日,判断这一天是这一年的第几天?
1. 程序分析: 以 3 月 5 日为例, 应该先把前两个月的加起来, 然后再加上 5 天即本年的第几
天,特殊情况,闰年且输入月份大于 3 时需考虑多加一天。
2. 程序源代码:
#include<iostream>
using namespace std;
int main()
{
int day,month,year,sum,leap;
cout<<"please input year,month,day:";
cin>>year>>month>>day;
switch(month)/* 先计算某月以前月份的总天数 */
{
case 1:sum=0;
break;
case 2:sum=31;
break;
case 3:sum=59;
break;
case 4:sum=90;
break;
case 5:sum=120;
break;
case 6:sum=151;
break;
case 7:sum=181;
break;
case 8:sum=212;
break;
case 9:sum=243;
break;
case 10:sum=273;
break;
case 11:sum=304;
break;
case 12:sum=334;
break;
default:
cout<<"error";
}
sum+=day;
/* 再加上某天的天数 */
if(year%400==0||(year%4==0&&year%100!=0))/* 判断是不是闰年 */
leap=1;
else
leap=0;
if(leap==1&&month>2)/* 如果是闰年且月份大于 2, 总天数应该加一天 */
sum++;
cout<<"It is the day:"<<sum<<endl;
return 0;}
运行结果:
please input year,month,day:2001 5 3
It is the day:123
==============================================================
【程序 5】
题目:输入三个整数 x,y,z ,请把这三个数由小到大输出。
1. 程序分析:我们想办法把最小的数放到 x 上,先将 x 与 y 进行比较,如果 x〉y 则将 x 与
y 的值进行交换 , 然后再用 x 与 z 进行比较,如果 x〉z 则将 x 与 z 的值进行交换,这样能 x
最小。
2. 程序源代码:
#include<iostream>
using namespace std;
int main()
{
int x,y,z,t;
cin>>x>>y>>z;
if (x>y)
{t=x;x=y;y=t;} /* 交换 x,y 的值 */
if(x>z)
{t=z;z=x;x=t;}/* 交换 x,z 的值 */
剩余37页未读,继续阅读
资源评论
普通网友
- 粉丝: 4
- 资源: 10万+
下载权益
C知道特权
VIP文章
课程特权
开通VIP
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功