没有合适的资源?快使用搜索试试~ 我知道了~
【C程序100题】中的第一个程序是一个基础的C语言练习,旨在训练对数组和循环的掌握。问题要求计算1、2、3、4这四个数字可以组成多少个不同的三位数。程序通过三层嵌套循环实现,每层循环分别对应百位、十位和个位,以确保每个数字只使用一次。`if (i!=k&&i!=j&&j!=k)`语句用于检查三个变量i、j、k是否互不相同,以排除重复的组合。最终,程序打印出所有符合条件的三位数。 第二个程序涉及到百分比计算和利润提成。问题提出了一个奖金计算规则,根据利润的区间来决定不同的提成比例。程序使用条件语句(if-else)来判断输入的利润值属于哪个区间,并计算对应的奖金总额。在计算过程中,为了避免精度丢失,奖金被定义为长整型(`long int`)。程序打印出应发放的奖金总额。 第三个程序是一个关于完全平方数的问题。给定一个整数,需要找到这个数加上100和168后分别形成完全平方数的条件。程序通过循环遍历一定范围内的整数,用`sqrt()`函数计算平方根,然后检查开方结果的平方是否等于原数加上特定数值,从而确定完全平方数。 第四个程序涉及日期处理和闰年的判断。用户输入年、月、日,程序需要计算这一天是一年中的第几天。程序使用`switch`语句处理不同月份的天数,考虑到2月的天数可能因为闰年而有所不同。对于闰年的判断,通常2月会有29天。因此,如果输入的年份是闰年并且月份大于3,就需要额外加一天。 这些程序展示了C语言的基础应用,包括控制结构(如循环和条件语句)、基本数据类型(如整数和浮点数)、输入/输出操作以及数学运算。它们帮助初学者理解如何在实际问题中应用编程概念,同时也提供了对算法设计和问题解决策略的训练。
资源推荐
资源详情
资源评论
经典
c
程序
【程序 1】
题目:有 1、2、3、4 个数字,能组成多少
个互不相同且无重复数字的三位数?都是
多少?
1.程序分析:可填在百位、十位、个位的
数字都是 1、2、3、4。组成所有的排列后
再去掉不满足条件的排列。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int i,j,k;
printf("");
for(i=1;i<5;i++) /*以下为三重循环*/
for(j=1;j<5;j++)
for (k=1;k<5;k++)
{
if (i!=k&&i!=j&&j!=k) /*确保 i、j、k 三位
互不相同*/
printf("%d,%d,%d",i,j,k);
}getch();
}【程序 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.程序分析:请利用数轴来分界,定位。
注意定义时需把奖金定义成长整型。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{long int i;
int
bonus1,bonus2,bonus4,bonus6,bonus10,bonus
;
scanf("%ld",&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;
printf("bonus=%d",bonus)
getch();
}【程序 3】
题目:一个整数,它加上 100 后是一个完
全平方数,再加上 168 又是一个完全平方
数,请问该数是多少?
1.程序分析:在 10 万以内判断,先将该数
加上 100 后再开方,再将该数加上 268 后
再开方,如果开方后的结果满足如下条件
即是结果。请看具体分析:
2.程序源代码:
#include "math.h"
#include "stdio.h"
#include "conio.h"
main()
{
long int i,x,y,z;
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) /* 如 果 一 个
数的平方根的平方等于该数,这说明此数
是完全平方数*/
printf("%ld",i); }
第 1 页 共 29 页
经典
c
程序
getch();
}【程序 4】
题目:输入某年某月某日,判断这一天是
这一年的第几天?
1.程序分析:以 3 月 5 日为例,应该先把前
两个月的加起来,然后再加上 5 天即本年
的第几天,特殊
情况,闰年且输入月份大于 3 时需考虑多
加一天。、
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int day,month,year,sum,leap;
printf("\nplease input year,month,day\n");
scanf("%d,%d,%d",&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:printf("data error");break; }
sum=sum+day; /*再加上某天的天数*/
if(year%400==0||(year%4==0&&year%100!
=0)) /*判断是不是闰年*/
leap=1;
else
leap=0;
if(leap==1&&month>2) /* 如果是闰年且月
份大于 2,总天数应该加一天*/
sum++;
printf("It is the %dth day.",sum);
getch();
}【程序 5】
题目:输入三个整数 x,y,z,请把这三个数
由小到大输出。
1.程序分析:我们想办法把最小的数放到 x
上,先将 x 与 y 进行比较,如果 x>y 则将 x
与 y 的值进行交换,然后再用 x 与 z 进行
比较,如果 x>z 则将 x 与 z 的值进行交换,
这样能使 x 最小。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int x,y,z,t;
scanf("%d%d%d",&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 的值*/
if(y>z)
{t=y;y=z;z=t;} /*交换 z,y 的值*/
printf("small to big: %d %d %d\n",x,y,z);
getch();
}【程序 6】
题目:用*号输出字母 C 的图案。
1.程序分析:可先用'*'号在纸上写出字母
C,再分行输出。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{printf("Hello C-world!\n");
printf(" ****\n");
printf(" *\n");
printf(" * \n");
printf(" ****\n");
getch();
}【程序 7】
题目:输出特殊图案,请在 c 环境中运行,
看一看,Very Beautiful!
1.程序分析:字符共有 256 个。不同字符,
图形不一样。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{char a=176,b=219;
第 2 页 共 29 页
经典
c
程序
printf("%c%c%c%c%c\n",b,a,a,a,b);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",a,a,b,a,a);
printf("%c%c%c%c%c\n",a,b,a,b,a);
printf("%c%c%c%c%c\n",b,a,a,a,b);
getch();
}题目:输出 9*9 口诀。
1.程序分析:分行与列考虑,共 9 行 9 列,
i 控制行,j 控制列。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int i,j,result;
printf("\n");
for (i=1;i<10;i++)
{
for(j=1;j<10;j++)
{
result=i*j;
printf("%d*%d=%-3d",i,j,result); /*-3d 表 示
左对齐,占 3 位*/
}
printf("\n"); /*每一行后换行*/
}
getch();
}【程序 9】
题目:要求输出国际象棋棋盘。
1.程序分析:用 i 控制行,j 来控制列,根
据 i+j 的和的变化来控制输出黑方格,还是
白方格。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int i,j;
for(i=0;i<8;i++)
{
for(j=0;j<8;j++)
if((i+j)%2==0)
printf("%c%c",219,219);
else
printf(" ");
printf("\n");
}
getch();
}【程序 10】
题目:打印楼梯,同时在楼梯上方打印两
个笑脸。
1.程序分析:用 i 控制行,j 来控制列,j 根
据 i 的变化来控制输出黑方格的个数。
2.程序源代码:
#include "stdio.h"
#include "conio.h"
main()
{int i,j;
printf("\1\1\n"); /*输出两个笑脸*/
for(i=1;i<11;i++)
{
for(j=1;j<=i;j++)
printf("%c%c",219,219);
printf("\n");
}
getch();
}
【程序 】
题目:古典问题:有一对兔子,从出生后
第 个月起每个月都生一对兔子,小兔子
长到第三个月后每个月又生一对兔子,假
如兔子都不死,问每个月的兔子总数为多
少?
程序分析: 兔子的规律为数列
程序源代码:
!""
#$$
$!#%&'控制输出,
每行四个'&
"&'前两个月加起来赋值给第三
个月'&
第 3 页 共 29 页
经典
c
程序
"&'前两个月加起来赋值给第三
个月'&
(
(【程序 】
题目:判断 !)!! 之间有多少个素数,
并输出所有素数。
程序分析:判断素数的方法:用一个数
分别去除 到 *这个数,如果能被整
除,则表明此数不是素数,反之是素数。
程序源代码:
+!#
#%
! !!""
+*"
+""
$!
#!
,+
(
#
#$)-
""
$!!
#%
(
#
(
#%.$
(【程序 】
题目:打印出所有的“水仙花数”,所谓“水
仙花数”是指一个三位数,其各位数字立方
和等于该数本身。例如: 是一个“水仙
花数”,因为 的三次方+ 的三次
方+ 的三次方。
程序分析:利用 循环控制 !!)///
个数,每个数分解出个位,十位,百位。
程序源代码:
0+
#12321,4
!! !!!""
&!!&'分解出百位'&
0&!$!&'分解出十位'&
+$!&'分解出个位'&
'!!"0'!"+''"0'0'0"+'+'+
#$)
(
(【程序 -】
题目:将一个正整数分解质因数。例如:
输入 /!打印出 /!'''。
程序分析:对 进行分解质因数,应先找
到一个最小的质数 +,然后按下述步骤完
成:
如果这个质数恰等于 ,则说明分解质
因数的过程已经结束,打印出即可。
如果 5+,但 能被 + 整除,则应打
印出 + 的值,并用 除以 + 的商作为新的
正整数你 重复执行第一步。
如果 不能被 + 整除,则用 +" 作为
+ 的值重复执行第一步。
程序源代码:
&'678'&
#%##,4%
$9
#$
""
2:
第 4 页 共 29 页
经典
c
程序
$!
#$'
&
(
,+
(
#$
(【程序 】
题目:利用条件运算符的嵌套来完成此题:
学习成绩5/! 分的同学用 ; 表示,<!)
/ 分之间的用 = 表示,<! 分以下的用 >
表示。
程序分析:5,?4, 这是条件运算符
的基本例子。
程序源代码:
###%
$9
5/!?1;14
5<!?1=141>1
#$,
$
(程序 <】
题目:输入两个正整数 和 ,求其最大
公约数和最小公倍数。
程序分析:利用辗除法。
程序源代码:
,#
###2,4%
$$99
&'交换两个数,使大数
放在 上'&
#
#
(
,
2,:!&'利用辗除法,直到 , 为 !
为止'&
#$,
,
,#
(
#84$%
#,4$%
'&
(【程序 @】
题目:输入一行字符,分别统计出其中英
文字母、空格、数字和其它字符的个数。
程序分析:利用 2 语句条件为输入
的字符不为1%1
程序源代码:
!#!!!
###
%
2:1%1
51199 161AA
51;199 1B1
""
11
第 5 页 共 29 页
剩余28页未读,继续阅读
资源评论
meining123
- 粉丝: 0
- 资源: 1
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功