首页编程简单c语言程序编写例题,C语言编程例题

简单c语言程序编写例题,C语言编程例题

编程之家2026-05-29694次浏览

老铁们,大家好,相信还有很多朋友对于简单c语言程序编写例题和C语言编程例题的相关问题不太懂,没关系,今天就由我来为大家分享分享简单c语言程序编写例题以及C语言编程例题的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!

简单c语言程序编写例题,C语言编程例题

10道经典的C语言例题(含参考程序)

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

#include

#include

int main()

{

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

简单c语言程序编写例题,C语言编程例题

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

{

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))

简单c语言程序编写例题,C语言编程例题

{

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=min;i>0;i--)

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

{

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

break;

}

for(i=max;i<=x*y;i++)

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=0;i<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=0;i<n;i++) p=""></n;i++)>

{

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=2;i<=1000;i++)

{

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

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=0;i<n;i++) p=""></n;i++)>

sum=sum*a;

return sum;

}

int main()

{

int n,i,k,x;

printf("n=");

scanf("%d",&n);

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

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

{

printf("%d",i);

k=i;

break;

}

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

{

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=1;i<=20;i++)

{

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;

}

C语言编程小代码!一些C语言程序设计例题(二)

以下是针对用户提出的C语言程序设计例题的代码实现及简要说明:

1.字符串a下标值为偶数的元素由小到大排序,其他元素不变#include<stdio.h>#include<string.h>void sortEvenIndices(char*str){ int len= strlen(str); for(int i= 0; i< len; i+= 2){ for(int j= i+ 2; j< len; j+= 2){ if(str[i]> str[j]){ char temp= str[i]; str[i]= str[j]; str[j]= temp;}}}}int main(){ char a[]="abcdefgh"; printf("Original string:%sn", a); sortEvenIndices(a); printf("Sorted string:%sn", a); return 0;}说明:该程序通过双重循环对字符串中偶数下标的字符进行排序,保持奇数下标的字符不变。

2.十进制正整数转换为二进制#include<stdio.h>void decimalToBinary(int n){ if(n== 0){ printf("0"); return;} int binary[32]; int i= 0; while(n> 0){ binary[i++]= n% 2; n/= 2;} for(int j= i- 1; j>= 0; j--){ printf("%d", binary[j]);} printf("n");}int main(){ int num; printf("Enter a decimal number:"); scanf("%d",&num); printf("Binary representation:"); decimalToBinary(num); return 0;}说明:该程序通过不断除以2并取余数的方式将十进制数转换为二进制,然后逆序输出余数。

3.从低位开始取出整型变量n偶数位上的数依次放在整型变量s中#include<stdio.h>int extractEvenDigits(int n){ int s= 0; int position= 1; while(n> 0){ int digit= n% 10; if(digit% 2== 0){ s= s+ digit* position; position*= 10;} n/= 10;} return s;}int main(){ int n; printf("Enter an integer:"); scanf("%d",&n); int s= extractEvenDigits(n); printf("Result:%dn", s); return 0;}说明:该程序从低位开始检查每一位数字,如果是偶数则将其添加到结果变量s中,保持原有顺序。

4.输入并保存5名职工的信息,计算并输出平均工资,再按照工资从高到低的顺序输出#include<stdio.h>#include<string.h>typedef struct{ char id[10]; char name[9]; double salary;} Employee;void sortEmployees(Employee emp[], int n){ for(int i= 0; i< n- 1; i++){ for(int j= 0; j< n- i- 1; j++){ if(emp[j].salary< emp[j+ 1].salary){ Employee temp= emp[j]; emp[j]= emp[j+ 1]; emp[j+ 1]= temp;}}}}int main(){ Employee employees[5]; double total= 0; for(int i= 0; i< 5; i++){ printf("Enter details for employee%d:n", i+ 1); printf("ID:"); scanf("%s", employees[i].id); printf("Name:"); scanf("%s", employees[i].name); printf("Salary:"); scanf("%lf",&employees[i].salary); total+= employees[i].salary;} double average= total/ 5; printf("Average salary:%.1fn", average); sortEmployees(employees, 5); printf("Employees sorted by salary(descending):n"); for(int i= 0; i< 5; i++){ printf("ID:%s, Name:%s, Salary:%.1fn", employees[i].id, employees[i].name, employees[i].salary);} return 0;}说明:该程序使用结构体存储职工信息,计算平均工资后使用冒泡排序按工资降序排列职工信息。

5.求x的n次方(递归实现)#include<stdio.h>double power(double x, int n){ if(n== 0) return 1; if(n> 0) return x* power(x, n- 1); return 1/ power(x,-n);}int main(){ double x; int n; printf("Enter base and exponent:"); scanf("%lf%d",&x,&n); printf("Result:%.2fn", power(x, n)); return 0;}说明:该程序使用递归方式计算x的n次方,处理了正负指数的情况。

6.任意整数转换为千分位分隔的字符形式#include<stdio.h>#include<string.h>void formatWithCommas(int num){ char str[20]; sprintf(str,"%d", num); int len= strlen(str); int commaPos= len% 3; if(commaPos== 0&& len> 2) commaPos= 3; for(int i= 0; i< len; i++){ printf("%c", str[i]); if(--commaPos== 0&& i!= len- 1){ printf(","); commaPos= 3;}} printf("n");}int main(){ int number; printf("Enter an integer:"); scanf("%d",&number); printf("Formatted number:"); formatWithCommas(number); return 0;}说明:该程序将整数转换为字符串后,从右向左每三位插入一个逗号作为千分位分隔符。

以上代码均经过基本测试,可直接编译运行。如需进一步优化或有任何问题,请随时提出。

c语言咋么学啊能看懂例题,自己编程不会啊没有思路!

一,怎样学习C语言

很多人对学习C语言感到无从下手,经常问我同一个问题:究竟怎样学习C语言?我是一个教师,已经开发了很多年的程序,和很多刚刚起步的人一样,学习的第一个计算机语言就是C语言。经过这些年的开发,我深深的体会到C语言对于一个程序设计人员多么的重要,如果不懂C语言,你想写底层程序这几乎听起来很可笑,不懂C语言,你想写出优秀高效的程庌輌这简直就是天方夜谭。为什么C语言如此重要呢?

第一:C语言语法结构很简洁精妙,写出的程序也很高效,很便于描述算法,大多数的程序员愿意使用C语言去描述算法本身,所以,如果你想在程序设计方面有所建树,就必须去学它。

第二:C语言能够让你深入系统底层,你知道的操作系统,哪一个不是C语言写的?所有的windows,Unix,Linux,Mac,os/2,没有一个里外的,如果你不懂C语言,怎么可能深入到这些操作系统当中去呢?更不要说你去写它们的内核程序了。

第三:很多新型的语言都是衍生自C语言,C++,Java,C#,J#,perl...哪个不是呢?掌握了C语言,可以说你就掌握了很多门语言,经过简单的学习,你就可以用这些新型的语言去开发了,这个再一次验证了C语言是程序设计的重要基础。还有啊,多说一点:即使现在招聘程序员,考试都是考C语言,你想加入it行业,那么就一定要掌握好C语言。

那么究竟怎样学习C语言呢?

1:工欲善其事,必先利其器这里介绍几个学习C语言必备的东东:一个开发环境,例如turbo C 2.0,这个曾经占据了DOS时代开发程序的大半个江山。但是现在windows时代,用turbo C有感觉不方面,编辑程序起来很吃力,并且拖放,更没有函数变量自动感应功能,查询参考资料也不方便。建议使用Visual C++,这个东西虽然比较大块头,但是一旦安装好了,用起来很方便。

一本学习教程,现在C语言教材多如牛毛,但推荐大家使用《C语言程序设计》谭浩强主编第二版清华大学出版社,此书编写的很适合初学者,并且内容也很精到。

除此以外,现在有很多辅助学习的软件,毕竟现在是Window时代了,学习软件多如牛毛,不象我们当初学习,只有读书做题这么老套。我向大家推荐一个“集成学习环境(C语言)”,里边的知识点总结和例程讲解都非常好,还有题库测试环境,据说有好几千题,甚至还有一个windows下的trubo C,初学者甚至不用装其它的编译器,就可以练习编程了,非常适合初学者。还有一个“C语言学习系统”软件,不过感觉只是一个题库系统,如果你觉得题做的不够,不妨也可以试试。

2:葵花宝典学习计算机语言最好的方法是什么?答曰:读程序。

没错,读程序是学习C语言入门最快,也是最好的方法。如同我,现在学习新的J#,C#等其他语言,不再是抱着书本逐行啃,而是学习它们的例程。当然,对于没有学过任何计算机语言的初学者,最好还是先阅读教程,学习完每一章,都要认真体会这一章的所有概念,然后不放过这一章中提到的所有例程,然后仔细研读程序,直到每一行都理解了,然后找几个编程题目,最好是和例程类似的或一样的,自己试图写出这段已经读懂的程序,不要以为例程你已经读懂了,你就可以写出和它一样的程序,绝对不一定,不相信你就试一试吧,如果写不出来,也不要着急,回过头来再继续研究例程,想想自己为什么写不出来,然后再去写这段程序,反反复复,直到你手到擒来为止,祝贺你,你快入门了。

3:登峰造极写程序的最高境界其实就是掌握各种解决问题的手段(数据结构)和解决问题的方法(算法)。

是不是写出底层程序就是程序设计高手呢?非也,写底层程序,无非是掌握了硬件的结构,况且硬件和硬件还不一样,要给一个芯片写驱动程序,无非就是掌握这块芯片的各种寄存器及其组合,然后写值读值,仅此而已。这不过是熟悉一些io函数罢了。那么怎样才算精通程序设计呢?怎样才能精通程序设计呢?举个例子:你面前有10个人,找出一个叫“张三”的人,你该怎么办?第一种方法:直接对这10个人问:“谁叫张三”。第2种方法:你挨个去问“你是不是张三?”,直到问到的这个人就是张三。第三种方法:你去挨个问一个人“你认不认识张三,指给我看”。不要小看这个问题,你说当然会选第一种方法,没错恭喜你答对了,因为这个方法最快,效率最高,但是在程序设计中找到解决问题的最优方法和你用的手段却是考验一个程序员程序设计水平的重要标志,而且是不容易达到的。刚才这个问题类似于数据结构和算法中的:Map数据结构,穷举查找和折半查找。所以掌握好数据结构和一些常用算法,是登峰造极的必然之路。最后给大家推荐严尉敏的《数据结构》清华大学出版社,希望每一个想成为程序设计高手的人研读此书。

有问题可以追问我;

如果对我的回答还满意

请随手采纳下啊!

谢谢楼主:!

OK,本文到此结束,希望对大家有所帮助。

java手机模拟器(java模拟器下载)web简单网页制作代码?HTML+CSS网页设计与制作