概述
1.
#include <stdio.h>
#include <stdlib.h>
int main()
{ int max_multiple(int,int);
int min_divisor(int,int);
int maxResult,minResult,a,b;
printf("请输入两个整数n");
scanf("%d %d",&a,&b);
maxResult=max_multiple(a,b);
minResult=min_divisor(a,b);
printf("最大公因数为: %dn",maxResult);
printf("最小公倍数为: %dn",minResult);
return 0;
}
int max_multiple(int a,int b)
{
if(a>=b)
{
int i;
for(i=b;i>=1;i--)
{
if(a%i==0&&b%i==0){
return i;
}
}
}
else{
int j;
for(j=a;j>=1;j--)
{
if(a%j==0&&b%j==0){
return j;
}
}
}
}
int min_divisor(int a,int b)
{
if(a>=b){
int i;
for(i=b;i<=a*b;i++){
if(i%a==0&&i%b==0){
return i;
}
}
}
else{
int i;
for(i=a;i<=a*b;i++){
if(i%a==0&&i%b==0){
return i;
}
}
}
}
2.
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
double delta_greater(double a,double b,double c);
double delta_equal(double a,double b,double c);
double delta_less(double a,double b,double c);
double a,b,c;
printf("请输入a,b,c的值n");
scanf("%lf %lf %lf",&a,&b,&c);
//printf("%f",b*b-4*a*c);
if((b*b-4*a*c)>0){
delta_greater(a,b,c);
}
else if((b*b-4*a*c)==0){
delta_equal(a,b,c);
}
else if((b*b-4*a*c)<0)
{
delta_less(a,b,c);
}
return 0;
}
double delta_greater(double a,double b,double c)
{
double x1,x2;
x1=(-b+sqrt(b*b-4*a*c))/(2*a);
x2=(-b-sqrt(b*b-4*a*c))/(2*a);
printf("此时有两个实根,分别为:x1=%f,x1=%f",x1,x2);
return 0;
}
double delta_equal(double a,double b,double c)
{
double x;
x=-b/(2*a);
printf("此时有两个相等的实根:x1=x2=%f",x);
return 0;
}
double delta_less(double a,double b,double c)
{
double p,q;
p=-b/(2*a);
q=sqrt(-(b*b-4*a*c))/(2*a);
printf("此时有两个共轭复根:x1=%f+%fi,x2=%f-%fi",p,q,p,q);
return 0;
}
3.
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
int judge_prime(int);
int x,result;
printf("请输入一个正整数n");
scanf("%d",&x);
if(judge_prime(x)==1)
{
printf("这个数不是素数");
}
else
{
printf("这个数是素数");
}
return 0;
}
int judge_prime(int x)
{
int i;
for(i=2;i<=sqrt(x);i++){
if(x%i==0){
return 1;
}
}
return 0;
}
4.
#include <stdio.h>
#include <stdlib.h>
#define N 3
int main()
{
int trans_array(int array[][3]);
int i,j,array[3][3];
printf("请输入一个二维数组:n");
for(i=0;i<N;i++){
for(j=0;j<N;j++){
scanf("%d",&array[i][j]);
}
}
printf("当前数组为:n");
for(i=0;i<N;i++){
for(j=0;j<N;j++){
printf(" %d ",array[i][j]);
}
printf("n");
}
trans_array(array);
return 0;
}
int trans_array(int a[][3])
{
int i,j,temp;
for(i=0;i<N;i++){
for(j=0;j<i;j++)
{
temp=a[i][j];
a[i][j]=a[j][i];
a[j][i]=temp;
}
}
printf("转置后的数组为:n");
for(i=0;i<N;i++){
for(j=0;j<N;j++){
printf(" %d ",a[i][j]);
}
printf("n");
}
return 0;
}
5.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
void reverse_str(char a[]);
printf("请输入一个字符串n");
char a[10];
gets(a);
reverse_str(a);
printf("反序存放结果为:n");
puts(a);
return 0;
}
void reverse_str(char a[])
{
int i,j;
j=strlen(a);
char temp;
for(i=0;i<j/2;i++){
temp=a[i];
a[i]=a[j-i-1];
a[j-i-1]=temp;
}
return a;
}
6.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
void catenate_str(char a[],char b[]);
char a[50],b[20];
printf("请输入第一个字符串n");
gets(a);
printf("请输入第二个字符串n");
gets(b);
printf("连接结果为:n");
catenate_str(a,b);
puts(a);
return 0;
}
void catenate_str(char a[],char b[])
{
strcat(a,b);
}
7.
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
void copy_str(char a[],char b[]);
char a[50],b[50];
printf("请输入一个字符串n");
gets(a);
printf("其中的元音字母有:n");
copy_str(a,b);
puts(b);
return 0;
}
void copy_str(char a[],char b[])
{
int i,j;
for(i=0,j=0;i<strlen(a);i++)
{
if(a[i]=='a'||a[i]=='e'||a[i]=='i'||a[i]=='o'||a[i]=='u'||a[i]=='A'||a[i]=='E'||a[i]=='I'||a[i]=='O'||a[i]=='U')
{
b[j]=a[i];
j++;
}
}
b[j]='