经典C语言程序例子

Python018

经典C语言程序例子,第1张

题目01:在一个已知的字符串中查找最长单词,假定字符串中只含字母和空格,空格用来分隔不同的单词。

直接编译,程序执行结果如下图所示:

题目02:编写一个int string_len(char *s),返回字符串s的字符长度(不包括\0)。

直接编译,程序执行结果如下图所示:

扩展资料:

C语言是一门通用计算机编程语言,应用广泛。C语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

尽管C语言提供了许多低级处理的功能,但仍然保持着良好跨平台的特性,以一个标准规格写出的C语言程序可在许多电脑平台上进行编译,甚至包含一些嵌入式处理器(单片机或称MCU)以及超级电脑等作业平台。

1.打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个“水仙花数”,因为153=1^3+5^3+3^3。

#include

#include

int main()

{

int bai_wei,shi_wei,ge_wei,i,sum=0

for(i=100i<1000i++)

{

bai_wei=i/100

shi_wei=(i%100)/10

ge_wei=i%10

if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))

{

printf("%d ",i)

sum++

if(sum%5==0)

printf(" ")

}

}

printf(" ")

return 0

}

2.请输入任意两个整数x和y,求其最大公约数和最小公倍数。

#include

int main()

{

int x,y,min,max,i

printf("请输入任意两个整数:")

scanf("%d%d",&x,&y)

min=x>y?y:x

max=x>y?x:y

for(i=mini>0i--)

if(x%i==0&&y%i==0)

{

printf("这两个整数的最大公约数为:%d ",i)

break

}

for(i=maxi<=x*yi++)

if(i%x==0&&i%y==0)

{

printf("这两个整数的最小公倍数为:%d ",i)

break

}

return 0

}

3.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

#include

#include

#define N 50

int main()

{

int sum1=0,sum2=0,sum3=0,sum4,i=0

char str[N]

printf("请输入一串字符串:")

scanf("%s",str)

for(i=0i<strlen(str)i++) p=""></strlen(str)i++)>

{

if((str[i]>='a'&&str[i]='A'&&str[i]<='Z'))

sum1++

if(str[i]==' ')

sum2++

if(str[i]>='0'&&str[i]<='9')

sum3++

}

sum4=strlen(str)-sum1-sum2-sum3

printf("英文字母的个数:%d ",sum1)

printf("空格的个数:%d ",sum2)

printf("数字的个数:%d ",sum3)

printf("其他符号的个数:%d ",sum4)

return 0

}

4.求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

#include

#include

int main()

{

int a,n,s=0,i,x=0,y=0

printf("请输入整数a的值:")

scanf("%d",&a)

printf("请输入相加的个数n:")

scanf("%d",&n)

for(i=0i<ni++) p=""></ni++)>

{

x=y+2*pow(10,i)

y=x

s=s+x

}

printf("s=%d ",s)

return 0

}

5.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。

#include

int main()

{

int sum=0,i,j

printf("在1000以内的完数有:")

for(i=2i<=1000i++)

{

for(j=1j<ij++) p=""></ij++)>

if(i%j==0)

sum=sum+j

if(sum==i)

printf("%d ",i)

sum=0

}

printf(" ")

return 0

}

6.输入一个不多于5位的正整数,要求:1、求它是几位数;2、逆序打印出个位数字。

#include

int pows(int a,int n)

{

int sum=1,i

for(i=0i<ni++) p=""></ni++)>

sum=sum*a

return sum

}

int main()

{

int n,i,k,x

printf("n=")

scanf("%d",&n)

for(i=1i<6i++)

if(n/pows(10,i)==0)

{

printf("%d ",i)

k=i

break

}

for(i=0i<ki++) p=""></ki++)>

{

x=n/pows(10,i)%10

printf("%d",x)

}

printf(" ")

return 0

}

7.输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

#include

int main()

{

int n,a[5],i=0

printf("请输入一个5位数:")

scanf("%d",&n)

while(n!=0)

{

a[i]=n%10

n=n/10

i++

}

if(a[0]==a[4]&&a[1]==a[3])

printf("这个数是回文数 ")

else

printf("这个数不是回文数 ")

return 0

}

8.利用递归算法,将所输入的5个字符,以相反顺序打印出来。

#include

void digui(char a[],int n)

{

if(n==1)

printf("%c",a[0])

else

{

printf("%c",a[n-1])

digui(a,n-1)

}

}

int main()

{

char str[5]

printf("请输入5个字符:")

scanf("%s",str)

digui(str,5)

printf(" ")

return 0

}

9.有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…球出这个序列的前20项之和。

#include

int main()

{

int i,a=1,b=1

float sum=0.0

for(i=1i<=20i++)

{

sum=sum+(float)(a+i)/b

b=a+i

a=i

}

printf("sum=%f ",sum)

return 0

}

10.利用递归算法求5!。

#include

int digui(int n)

{

if(n==1)

return 1

else

return n*digui(n-1)

}

int main()

{

int n,sum

printf("n:")

scanf("%d",&n)

sum=digui(n)

printf("sum=%d ",sum)

return 0

}

#include <stdio.h>

main(int a,char **date)

{

int year=0,month=0,day=0,week

int d,i,dm,dy,m2

char WEEK[9]

if (a==1)

{

printf ("\n ERROR! you forgot to enter the date you want to view\n")

exit (0)

}

i=0d=-1

while (date[1][i])/*遍历传入的参数日期,计算出year,month,day*/

{

if ((date[1][i]=='/'||date[1][i]=='.')&&d==-1) { d=0i++continue}

if ((date[1][i]=='/'||date[1][i]=='.')&&d==0) { d=1i++continue}

if (d==-1) year=year*10+(date[1][i]-'0')

if (d==0) month=month*10+(date[1][i]-'0')

if (d==1) day=day*10+(date[1][i]-'0')

i++

}

if (month<1||month>12)/*若月份传入错误数字*/

{

printf ("\n ERROR! the entered MONTH is invalid\n")

exit (0)

}

if (year==2000)

{

dy=0 /*年引起的星期差为0个*/

m2=1 /*2月引起的星期差为1个*/

goto la_100

}

if (year>2000)

d=(year-1-2000)/4-(year-1-2000)/100+(year-1-2000)/400+1

else

d=(year-2000)/4-(year-2000)/100+(year-2000)/400

dy=(year-2000)+d/*** 该年 1月1号 到2000年1月1号的 " 星期差 " ***/

if((year%4==0&&year%100!=0)||(year%100==0&&year%400==0))

m2=1

else

m2=0 /*** 该年是否润 ***/

la_100:/**** la_100 ****/

/*** 该月以前的月所引起的 " 星期差 " ***/

switch (month)

{

case 1: dm=0month=31break /*** month 在此存放该月天数 ***/

case 2: dm=3month=d==1? 29:28break

case 3: dm=3+m2month=31break

case 4: dm=6+m2month=30break

case 5: dm=1+m2month=31break

case 6: dm=4+m2month=30break

case 7: dm=6+m2month=31break

case 8: dm=2+m2month=31break

case 9: dm=5+m2month=30break

case 10: dm=m2month=31break

case 11: dm=3+m2month=30break

case 12: dm=5+m2month=31break

}

if (day<0||day>month)

{

printf ("\n ERROR! the entered DAY is invalid\n")

exit (0)

}

week=(dy+dm+day-1+6)%7

if(week<0)

week+=7

if (day>0) /*** 判定查看类型 ***/

{

switch (week)

{

case 0: strcpy (WEEK,"SUNDAY")break

case 1: strcpy (WEEK,"MONDAY")break

case 2: strcpy (WEEK,"TUESDAY")break

case 3: strcpy (WEEK,"WEDNESDAY")break

case 4: strcpy (WEEK,"THURSDAY")break

case 5: strcpy (WEEK,"FRIDAY")break

case 6: strcpy (WEEK,"SATURDAY")break

}

printf ("\n this day is %s \( %d \)\n\n OK!\n",WEEK,week)

}

else

{

week=++week%7

printf ("\n the calender of this month as following\n")

printf ("\n *********************************\n")

printf (" SUN MON TUE WEN THU FRI STA\n")

for (i=0i<weeki++)

printf (" ")

for (i=1i<=monthi++)

{

printf (" %2d ",i)

week++

if (week%7==0&&i!=month)

printf ("\n")

}

printf ("\n *********************************\n")

printf ("\n OK!\n")

}

}

这是一个万年历的小程序,效率不怎么高,不过涉及到很多基础知识,可以读读