使用if多分支结构:
c
#include<stdio.h>
int main()
{
int score
printf("请输入学生的成绩:\n")
scanf("%d", &score)
if(score>=90 &&score<=99){
printf("学生的成绩等级为A\n")
}else if(score>=80 &&score<=89){
printf("学生的成绩塌搜等级为B\n")
}else if(score>=70 &&score<=79){
printf("学生的成绩等级为C\n")
}else if(score>=60 &&score<=69){
printf("学生的成绩等级为D\n")
}else if(score>=0 &&score<=59){
printf("学生的成绩等级为E\n")
}else{
printf("输入的成绩不合法\n")
}
return 0
}
使用switch多团野历分支结构:
c
#include<stdio.h>
int main()
{
int score
printf("请输入学生的成绩:\n")
scanf("%d", &score)
switch(score/10){
case 10:
case 9:
printf("学生的成绩等级为A\n")
break
case 8:
printf("学生的成绩等级为B\n")
break
case 7:
printf("学生的成绩等级为C\n")
break
case 6:
printf("学生的成绩等级为D\n")
break
default:
if(score>=0 &&score<=59){
printf("学生的成绩等级为脊庆E\n")
}else{
printf("输入的成绩不合法\n")
}
break
}
return 0
}
题目2:
c
#include<stdio.h>
#include<math.h>
int is_prime(int num)
{
int i
for(i=2i<=sqrt(num)i++){
if(num%i == 0){
return 0
}
}
return 1
}
int main()
{
int num
printf("请输入一个整数:\n")
scanf("%d", &num)
if(is_prime(num)){
printf("%d是素数\n", num)
}else{
printf("%d不是素数\n", num)
}
return 0
}
题目3:
c
#include<stdio.h>
#define N 5
int main()
{
int arr[N]
int i, temp
printf("请输入%d个数:\n", N)
for(i=0i<Ni++){
scanf("%d", &arr[i])
}
for(i=0i<N/2i++){
temp = arr[i]
arr[i] = arr[N-1-i]
arr[N-1-i] = temp
}
printf("逆序输出数组:")
for(i=0i<Ni++){
printf("%d ", arr[i])
}
printf("\n")
return 0
}
下面是一个可以利用指针将两个字符串连接起来的 C 语言程序。该程序定义了一个子函数 `StrCat`,用于将两个字符串连接起来,并返回连接后的结果。主函数中,我们先从标准输入读入两个字符串,然后根据它们的长度调用 `StrCat` 函数,将它们连接起来并输出结果。```c
#include <stdio.h>
#include <string.h>
#define MAX_LEN 100
char* StrCat(char* s, char* t)
int main() {
char s1[MAX_LEN], s2[MAX_LEN]
// 从标准输入读入两个字符串
printf("请输入第一个字符串:")
fgets(s1, MAX_LEN, stdin)
printf("请输入第二个字符串:")
fgets(s2, MAX_LEN, stdin)
// 将短的字符串放在前面,然后连接两个字符串
if (strlen(s1) >strlen(s2)) {
char *t = s1
s1 = s2
s2 = t
}
StrCat(s1, s2)
// 输出结果
printf("连接后的字符串为:%s", s1)
return 0
}
char* StrCat(char* s, char* t) {
int i, j
// 找到罩州仔 s 末尾位置
for (i = 0s[i] != '\0'i++)
// 将 t 中的字符复制到 s 的末尾
for (j = 0t[j] != '\0'j++) {
s[i + j] = t[j]
}
s[i + j] = '\0'
return s
}
```
在这个程序中,我们首先定义了子函数 `StrCat`,该函数接受两迹嫌个指向字符数组的指针 `s` 和 `t`,将 `t` 中的字符连接到 `s` 的末尾,并返回连接后的结果。具体来说,我们首先找到 `s` 的末尾位置,然后使用循环遍历 `t` 中的每个字符,并将它们复制到 `s` 的末尾。
在主函数中,我们先从标准输入读入两个字符串,并使用 `strlen` 函数获取它们的长度。然后,我们判断哪个字符物汪串比较短,将其放在前面,并调用 `StrCat` 函数将两个字符串连接起来。最后,我们使用 `printf` 函数输出连接后的字符串。
需要注意的是,在函数 `StrCat` 中,我们没有对输入数据进行任何检查(例如,字符串的长度是否超过了数组的大小等)。如果需要确保输入数据的有效性,可以在程序中添加相应的检查代码。
您好,c语言经典100题:【程序1】
题目:有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数
都是多少
1.程序分析:可填在百位,十位,个位的数字都是1,2,3,4.组成所有的排列后再去
掉不满足条件的排列.
2.程序源代码:
main()
{
int
i,j,k
printf("\n")
for(i1i<5i++)
/*以下为三重循环*/
for(j1j<5j++)
for
(k1k<5k++)
{
if
(i!k&&i!j&&j!k)
/*确保i,j,k三位互不相同*/
printf("%d,%d,%d\n",i,j,k)
}
}
【程序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.程序源代码:
main()
{
long
int
i
int
bonus1,bonus2,bonus4,bonus6,bonus10,bonus
scanf("%ld",&i)
bonus1100000*0.1bonus2bonus1+100000*0.75
bonus4bonus2+200000*0.5
bonus6bonus4+200000*0.3
bonus10bonus6+400000*0.15
if(i<100000)
bonusi*0.1
else
if(i<200000)
bonusbonus1+(i-100000)*0.075
else
if(i<400000)
bonusbonus2+(i-200000)*0.05
else
if(i<600000)
bonusbonus4+(i-400000)*0.03
else
if(i<1000000)
bonusbonus6+(i-600000)*0.015
else
bonusbonus10+(i-1000000)*0.01
printf("bonus%d",bonus)
}
【程序3】
题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少
1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后
的结果满足如下条件,即是结果.请看具体分析:
2.程序源代码:
#include
"math.h"
main()
{
long
int
i,x,y,z
for
(i1i2)/*如果是闰年且月份大于2,总天数应该加一天*/
sum++
printf("it
is
the
%dth
day.",sum)}
【程序4】
题目:输入某年某月某日,判断这一天是这一年的第几天?
1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊
情况,闰年且输入月份大于3时需考虑多加一天。
2.程序源代码:
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:sum0break
case
2:sum31break
case
3:sum59break
case
4:sum90break
case
5:sum120break
case
6:sum151break
case
7:sum181break
case
8:sum212break
case
9:sum243break
case
10:sum273break
case
11:sum304break
case
12:sum334break
default:printf("data
error")break
}
sumsum+day
/*再加上某天的天数*/
if(year%4000||(year%40&&year%100!0))/*判断是不是闰年*/
leap1
else
leap0
if(leap1&&month>2)/*如果是闰年且月份大于2,总天数应该加一天*/
sum++
printf("It
is
the
%dth
day.",sum)}
【程序5】
题目:输入三个整数x,y,z,请把这三个数由小到大输出.
1.程序分析:我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,
然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小.
2.程序源代码:
main()
{
int
x,y,z,t
scanf("%d%d%d",&x,&y,&z)
if
(x>y)
{txxyyt}
/*交换x,y的值*/
if(x>z)
{tzzxxt}/*交换x,z的值*/
if(y>z)
{tyyzzt}/*交换z,y的值*/
printf("small
to
big:
%d
%d
%d\n",x,y,z)
}
【程序6】
题目:用*号输出字母c的图案.
1.程序分析:可先用'*'号在纸上写出字母c,再分行输出.
2.程序源代码:
#include
"stdio.h"
main()
{
printf("hello
c-world!\n")
printf("
****\n")
printf("
*\n")
printf("
*
\n")
printf("
****\n")
}
【程序7】
题目:输出特殊图案,请在c环境中运行,看一看,very
beautiful!
1.程序分析:字符共有256个.不同字符,图形不一样.
2.程序源代码:
#include
"stdio.h"
main()
{
char
a176,b219
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)}
【程序8】
题目:输出9*9口诀.
1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列.
2.程序源代码:
#include
"stdio.h"
main()
{
int
i,j,result
printf("\n")
for
(i1i<10i++)
{
for(j1j<10j++)
{
resulti*j
printf("%d*%d%-3d",i,j,result)/*-3d表示左对齐,占3位*/
}
printf("\n")/*每一行后换行*/
}
}
【程序9】
题目:要求输出国际象棋棋盘.
1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格.
2.程序源代码:
#include
"stdio.h"
main()
{
int
i,j
for(i0i<8i++)
{
for(j0j<8j++)
if((i+j)%20)
printf("%c%c",219,219)
else
printf("
")
printf("\n")
}
}
【程序10】
题目:打印楼梯,同时在楼梯上方打印两个笑脸.
1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数.
2.程序源代码:
#include
"stdio.h"
main()
{
int
i,j
printf("\1\1\n")/*输出两个笑脸*/
for(i1i<11i++)
{
for(j1j<ij++)
printf("%c%c",219,219)
printf("\n")
}
}
【程序11】
题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月
后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少
1.程序分析:
兔子的规律为数列1,1,2,3,5,8,13,21....
2.程序源代码:
main()
{
long
f1,f2
int
i
f1f21
for(i1i<20i++)
{
printf("%12ld
%12ld",f1,f2)
if(i%20)
printf("\n")/*控制输出,每行四个*/
f1f1+f2
/*前两个月加起来赋值给第三个月*/
f2f1+f2
/*前两个月加起来赋值给第三个月*/
}
}
【程序12】
题目:判断101-200之间有多少个素数,并输出所有素数.
1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,
则表明此数不是素数,反之是素数.
2.程序源代码:
#include
"math.h"
main()
{
int
m,i,k,h0,leap1
printf("\n")
for(m101m<200m++)
{
ksqrt(m+1)
for(i2i<ki++)
if(m%i0)
{leap0break}
if(leap)
{printf("%-4d",m)h++
if(h%100)
printf("\n")
}
leap1
}
printf("\nthe
total
is
%d",h)
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)