1、水仙花数
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数
本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
方法一:
#include
int main(int argc, const char *argv[])
{
for(int i=1;i
int main()
{
int i,j,k,n;
printf("'water flower'number is:");
for(n=100;n
2、整型数组内函数求和。
使用函数封装,实现一个整型数组内数据的求和。
#include
int array_sum(int *data,int n);
int main(int argc, const char *argv[])
{
int a[]={1,2,3,4,5,6,7,8};
int sum=0;
sum=array_sum(a,sizeof(a)/sizeof(int));
printf("sum=%dn",sum);
return 0;
}
int array_sum(int *data,int n){
int ret=0;
int i;
for(i=0;i
3、斐波那契数列
斐波那契数列(Fibonacci sequence),又称黄金分割数列,因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……
#include
int main(int argc, const char *argv[])
{
int arr[15];
arr[0]=1;
arr[1]=1;
for(int i=2;i
4、杨辉三角
杨辉三角的每行行首与每行结尾的数都为1.而且,每个数等于其左上及其正上二数的和。
#include
int main(int argc, const char *argv[])
{
int a[15][15]={{0}};
int i,j;
for(i=0;i
5、猴子吃桃子
一只小猴子一天摘了许多桃子,第一天吃了一半,然后忍不住多吃了一个。第二天又吃了一半,再加上一个;后面每天都是这样吃.到第10天的时候,小猴子发现只有一个桃子了。
问小猴子第一天共摘了多少个桃子?
用递归函数求得小猴子第一天共摘了多少个桃子。
#include
int tao(int n);
int main(int argc, const char *argv[])
{
printf("%dn",tao(10));
return 0;
}
int tao(int n){
if(n==1){
return 1;
}
return (tao(n-1)+1)*2;
}
6、编写一个时钟
#include
int main(int argc, const char *argv[])
{
int year,month,day, hour,min,sec;
scanf("%d %d %d %d %d %d",&year,&month,&day,&hour,&min,&sec);
while(1){
sleep(1);
if(sec
7、字符串中计算某字符出现的次数
写一个函数有两个参数,第一个参数是个字符,第二个参数是个char *,
函数功能为返回这个字符串中该字符的个数。
#include
int func(char a,char *b);
int main(int argc, const char *argv[])
{
char c;
char s[30]={0};
printf("Please input char:n");
scanf("%c",&c);
getchar();
printf("Please input string:n");
gets(s);
func(c,s);
return 0;
}
int func(char a,char *b){
int i=0;
while(*b){
if(a==*b){
i++;
}
*b++;
}
printf("%dn",i);
}
8、逆序输出
一、逆序输出字符串
#include
int main(int argc, const char *argv[])
{
int arr[10];
for(int i=0;i=0;i--)
printf("%dt",arr[i]);
putchar('n');
return 0;
}
二、逆序输出数组中的数据
#include
int main(int argc, const char *argv[])
{
int a[]={1,2,3,4,5,6};
int *p,*q,n,i,temp;
n=sizeof(a)/sizeof(int);
p=a;
q=&a[n-1];
while(p
9、字符串中删除重复字符
#include
#include
int main(int argc, const char *argv[])
{
char s[100];
printf("input:");
gets(s);
int n=strlen(s);
for(int i=0;i
10、用函数封装实现字符串拼接
#include
char *strcat(char *a,char *b);
int main(int argc, const char *argv[])
{
char a[50]="hello";
char b[]="word";
puts(strcat(a,b));
return 0;
}
char *strcat(char *a,char *b){
char *c=a;
while(*a){
a++;
}
while(*b){
*a=*b;
a++;
b++;
}
*a=' ';
return c;
}
11、删除字符串中的空格
#include
#include
void del_space(char *s1);
int main(int argc, const char *argv[])
{
char s[]="a d gg sd ";
puts(s);
del_space(s);
puts(s);
return 0;
}
void del_space(char *s1)
{
char *s2;
s2=s1;
while(*s1){
if(*s1==' ')
{
s1++;
}else{
*s2=*s1;
s1++;
s2++;
}
}
*s2=' ';
}
12、求字符串中数字字符个数及把数字字符转换成数字求和。
#include
int main(int argc, const char *argv[]){
char s[100];
int i=0;
int j=0;
int sum=0;
gets(s);
//puts(s);
while(s[i]!=' '){
if('0'
13、二维数组中求出最大值及最大值所在的行数和列数。
#include
int main(int argc, const char *argv[])
{
int a[3][3]={{1,2,3},{4,5,6},{7,8,9}};
int i,j,row,cloumn;
row=cloumn=0;
for(i=0;i
14、冒泡排序
#include
int main(int argc, const char *argv[])
{
int i,j,temp;
int arr[5]={0};
printf("input:");
for(i=0;iarr[j+1]){
temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
printf("排序后为:");
for(i=0;i
15、实现两个数的交换(函数封装)
#include
void swap(int *x, int *y);
int main(int argc, const char *argv[])
{
int a;
int b;
scanf("%d",&a);
scanf("%d",&b);
swap(&a,&b);
printf("%dn",a);
printf("%dn",b);
return 0;
}
void swap(int *x, int *y){
int temp;
temp=*x;
*x=*y;
*y=temp;
}
16、简易超市结账系统
#include
int main(int argc, const char *argv[])
{ int n;
double m;
printf("***********************************************n");
printf("欢迎你来给我送钱,请按以下步骤进行送钱程序n");
printf("1、是尊贵会员请输入1以及消费金额n");
printf("2、不是尊贵会员请输入2以及消费金额n");
printf("***********************************************n");
scanf("%d %lf",&n,&m);
if(n=1){
if(m
17、完数
一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程
找出1000以内的所有完数。
#include
int main(int argc, const char *argv[])
{
int i,j,sum;
for (i=3;i
18、简单选择排序
#include
#define N 5
int main(int argc, const char *argv[])
{
int i,j,k,temp;
int num[N];
printf("input num:",N);
for(i=0;i
19、用函数封装思想实现strncpy
#include
int main(int argc, const char *argv[])
{printf("please input two string and n:n");
char a[100];
gets(a);
char b[100];
gets(b);
int n;
scanf("%d",&n);
char *p=a;
char *q=b;
int i=0;
while(*q&&i
20、实现strcmp的功能
#include
int main(int argc, const char *argv[])
{
printf("please input two string :n");
char a[100];
gets(a);
char b[100];
gets(b);
char *p=a;
char *q=b;
while (*p&&*q){
if(*p*q){
printf("1n");
return 0;
}else{
p++;
q++;
if((*p==' ')&&(*q==' ')){
printf("0n");
return 0;
}
}
}
if(*p){
printf("1");
}else{
printf("-1");
}
return 0;
}
21、用函数封装实现strcat的功能
方式一(最后添加' '):
#include
#include
void mystrcat(char *x,char *y);
int main(int argc, const char *argv[])
{
char a[100];
char b[100];
gets(a);
gets(b);
mystrcat(a,b);
puts(a);
return 0;
}
void mystrcat(char *x,char *y){
x=x+strlen(x);
while(*y){
*x=*y;
x++;
y++;
}
*x=' ';
}
方式二(初始化数组' '):
#include
#include
void mystrcat(char *x,char *y);
int main(int argc, const char *argv[])
{
char a[100]={0};
char b[100]={0};
gets(a);
gets(b);
mystrcat(a,b);
puts(a);
return 0;
}
void mystrcat(char *x,char *y){
x=x+strlen(x);
while(*y){
*x=*y;
x++;
y++;
}
//*x=' ';
}
方式二(定义全局变量' '):
#include
#include
void mystrcat(char *x,char *y);
char a[100];
char b[100];
int main(int argc, const char *argv[])
{
gets(a);
gets(b);
mystrcat(a,b);
puts(a);
return 0;
}
void mystrcat(char *x,char *y){
x=x+strlen(x);
while(*y){
*x=*y;
x++;
y++;
}
//*x=' ';
}
22、用sqrt 实现求三角形面积
#include //编译时加-lm
#include
int main(int argc, const char *argv[])
{
double area;
double a,b,c,s,n;
printf("请输入三角形的三边长n");
scanf("%lf",&a);
scanf("%lf",&b);
scanf("%lf",&c);
if((a+b)>c&&(a+c)>b&&(b+c)>a){
s=1.0/2*(a+b+c);
area=sqrt(s*(s-a)*b*c);
printf("%lf",area);
putchar('n');
} else{
printf("erro");
putchar('n');
}
return 0;
}
23、输入整数转换为字符串
#include
char *zhuan(char *p,int n);
int main(int argc, const char *argv[])
{char s[50],*r;
int n;
printf("请输入要转换为字符串的整数n");
scanf("%d",&n);
r=zhuan(s,n);
puts(r);
puts(s);
return 0;
}
char *zhuan(char *p,int n){
int r,i=0,j;
while(n){
r=n%10;
n=n/10;
p[i]=r+'0';
i++;
}
p[i]=' ';
j=i-1;
i=0;
while(i
24、简易实现手机商城功能
#include
typedef struct
{
int ID;
char Brand[10];
char Model[20];
char CPU[20];
float Price;
}PH;
void ui();
void input(PH ph[],int a);
void output(PH ph[],int a);
void selec(PH *p);
int num;
int main(int argc, const char *argv[])
{
while(1){
sleep(1);
ui();
int s;
PH ph[10];
PH *p=ph;
printf("please selec:n");
scanf("%d",&s);
switch(s)
{
case 1: input(ph,s);break;
case 2: output(ph,s);break;
case 3: return 0;
case 4:selec(p);break;
default:
puts("xia hu shu");
}
while(getchar()!='n');
}
return 0;
}
void input(PH ph[],int a){
int n=0;
printf("please input iphone num:n");
scanf("%d",&n);
printf("IDtBrandtModeltCPUtPricen");
for(int i=num;iPrice>=min&&(p+i)->PriceID);
}else{
printf("sorry,no phone");
}
}
}
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net