动态顺序字符串基本操作实验_大一 C语言 实验1

cc76f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验目的

掌握C语言中的变量、数组、函数、指针、结构体等主要知识点。

掌握C程序的结构化程序设计方法,能使用C语言开发简单的应用程序。

掌握C程序的运行、调试方法等。

二、 实验内容

(1)用函数调用实现求1~7的平方及平方和。

三、 实验步骤与过程

#include<stdio.h>

#include<math.h>

int pingfansum(int i,int q)

{

int sum1=0,l;

for(l=i;l<=q;l++)

sum1=sum1+l*l;

return sum1;

}

int main()

{

int i,a[7];

printf("1到7的平方和为%dn",pingfansum(1,7));

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

{

a[i-1]=i*i;

printf("第%d的平方是%d:n",i,a[i-1]);

}

return 0;

}

五、运行结果

d076f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(2)写一个判断素数的函数,在主函数中输入一个整数,输出是否是素数的信息。

二、实验步骤与过程

#include<stdio.h>

int isprime(int i)

{

int l,j;

if(i==2)

j=1;

for(l=2;l<i;l++)

{

if((i%l)!=0)

j=1;

else

{

j=0;

break;

}

}

return j;

}

int main()

{

int a;

printf("please input a number:n");

scanf("%d",&a);

if(isprime(a)==0)

printf("n不是素数n");

else

printf("n是素数n");

return 0;

}

三,实验结果

d176f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(3)写两个函数,分别求出两个整数的最大公约数和最小公倍数,在主函数中调用这两个函数并输出结果,整数由键盘输入。

二、实验步骤与过程

#include<stdio.h>

int gongyueshu(int a,int b)

{

int c;

while(a!=b)

{

c=a-b;

if(c>b)

a=c;

else

{

a=b;

b=c;

}

}

return b;

}

int main()

{

int a,b,temp,i,beishu;

printf("input two numbers n");

scanf("%d %d",&a,&b);

if(a<b)

{

temp=a;

a=b;

b=temp;

}

else if(a==b)

printf("error");

i=gongyueshu(a,b);

printf("最大公约数为%dn",i);

beishu=(a*b)/i;

printf("最小公倍数为%dn",beishu);

return 0;

}

三、运行结果

d276f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(4)写一个函数,使输入的字符串反序存放,在主函数中输入和输出字符串。

二,实验步骤与过程

# include <stdio.h>

# define n 255

void daoxu(char a[])

{

char temp;

int i,count=0;

for(i=0;a[i]!='0';i++)

count=count+1;

for(i=0;i<(count/2);i++)

{

temp=a[i];

a[i]=a[count-1-i];

a[count-1-i]=temp;

}

}

int main()

{

char a[n];

scanf("%s",&a);

daoxu(a);

printf("倒序的字符串为%sn",a);

return 0;

}

三、运行结果

d376f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(5)写一个函数,输入一个十六进制数,输出相应的十进制数。

二、实验步骤与过程

# include<stdio.h>

void jinzhi(int a)

{

printf("十进制数为%d",a);

}

int main()

{

int a;

printf("请输入十六进制数n");

scanf("%x",&a);

jinzhi(a);

return 0;

}

三、运行结果

d576f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(6)用递归法将一个整数n转换成字符串,例如,输入483,输出字符串“483”,n的位数不确定,可以是任意的整数。

二、实验步骤与过程

#include<stdio.h>

int a[100];

int k=0;

void f(int x)

{

int i;

a[k]=x%10;

if((i=x/10)!=0)

{

k++;

f(i);

}

}

void main()

{

int l,j;

printf("n");

scanf("%d",&l);

f(l);

for(j=k;j>=0&&a[j]!='0';j--)

printf("%d",a[j]);

}

三、运行结果

d676f8b6-4113-eb11-8da9-e4434bdf6706.png

二、 实验内容

(1)用函数调用实现求1~7的平方及平方和。

三、 实验步骤与过程

#include<stdio.h>

#include<math.h>

int pingfansum(int i,int q)

{

int sum1=0,l;

for(l=i;l<=q;l++)

sum1=sum1+l*l;

return sum1;

}

int main()

{

int i,a[7];

printf("1到7的平方和为%dn",pingfansum(1,7));

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

{

a[i-1]=i*i;

printf("第%d的平方是%d:n",i,a[i-1]);

}

return 0;

}

五、运行结果

d076f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

7)给出年、月、日,计算该日是该年的第几天。。

二、实验步骤与过程

#include<stdio.h>

int days(int year,int month, int day)

{

int Isdays=day;

int i;

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

{

if(i==1||i==3||i==5||i==7||i==8||i==10)

{

Isdays+=31;

}

else if(i==2)

{

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

Isdays+=29;

else

{

Isdays+=28;

}

}

else

{

Isdays+=30;

}

}

return Isdays;

}

int main()

{

int i, j ,k,day;

printf("请输入年月日n");

scanf("%d%d%d",&i,&j,&k);

day=days(i,j,k);

printf("该天是该年的第%d天",day);

return 0;

}

三,实验结果

ea76f8b6-4113-eb11-8da9-e4434bdf6706.png

一、 实验内容

(8)写一个函数,用“起泡法”对输入的10个字符按由小到大的顺序排列

二、实验步骤与过程

#include<stdio.h>

#include<string.h>

#define n 10

void str(char a[n])

{

int i,j;

char temp;

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

for(j=0;(j<n-i)&&a[j]!='0';j++)

if(a[j]>a[j+1])

{

temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

int main()

{

char a[n];

scanf("%s",&a);

if (strlen(a)!=10)

printf("error,please input 10 numbers");

else

{

str(a);

printf("%s",a);

};

return 0;

}

三,实验结果

ec76f8b6-4113-eb11-8da9-e4434bdf6706.png

ee76f8b6-4113-eb11-8da9-e4434bdf6706.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值