c语言中怎样写a的b次方,高手,请将整个程序写出来。谢谢
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言中怎样写a的b次方,高手,请将整个程序写出来。谢谢相关的知识,希望对你有一定的参考价值。
#include <stdio.h>int f(int x,int y);
int main()
int a,b;
printf("输入两个正整数:");
scanf("%d %d",&a,&b);
printf("a的b次方=%d\n",f(a,b));
return 0;
int f(int x,int y)
if(y==1)return x;
else
return x*f(x,y-1);
参考技术A #include<stdio.h>
#include<math.h>
int main()
int a,b,c;
scanf("%d%d",a,b);
c=pow(a,b);
printf("%d",c);
return 0;
追答
第五行错了应该是#include
#include
int main()
int a,b,c;
scanf("%d%d",&a,&b);
c=pow(a,b);
printf("%d",c);
return 0;
数组程序设计(用C语言写)
已知一个数组a大小为20个元素,用随机函数生成20个整数填充该数组,再将该数组元素从小到大排序。现要求任意输入三个整数,要求将该三个数插入数组中合适的位置,使得这个数组中的23个元素仍然按照从小到大的顺序排列,并将数组按下标顺序输出。 (一定要用C语言写出来哦)谢谢了!
#include <stdio.h>#include <stdlib.h>
#include <time.h>
/*插入元素的函数fun()*/
void fun(int *b ,int n)
int i,j;
for(i=0;b[i]<n;i++);
for(j=22;j>i;j-- )b[j]=b[j-1];
b[i]=n;
void main()
int a[23]=0;
int i,j,t,n;
/*随机产生数组并使数组无相等元素*/
srand( (unsigned)time( NULL ) );/*设置种子使每次执行随机函数产生数组不一样*/
for(i=0;i<20;i++)
a[i]=rand();
for(j=0;i<i;j++)
if(a[i]==a[j])
i--;
/*数组排序*/
for(i=0;i<20;i++)
for(j=i+1;j<20;j++)
if(a[i]>a[j])t=a[i];a[i]=a[j];a[j]=t;
/*输出初始数组*/
for(i=0;i<20;i++)
if(i%5==0)printf("\n");
printf(" %8d ",a[i]);
printf("\n");
/*输入三个数字并插入*/
printf("输入三个整数 ");
scanf("%d",&n);fun(a,n);
scanf("%d",&n);fun(a,n);
scanf("%d",&n);fun(a,n);
/*输出新数组*/
for(i=0;i<23;i++)
if(i%5==0)printf("\n");
printf(" %8d ",a[i]);
printf("\n");
参考技术A 这个,首先建议一下,求代码这种事是一个非常不好的习惯,不管怎么说,哪怕你再初学,对着教科书也绝对能写出类似的代码。
还有一点,如果想学好编程,最好去CSDN问,别在BAIDU这种不专业的地方问。
代码如下,我用的是VS2005编译,可正常使用,如果要用其它IDE,请将最开头的#include "stdafx.h"删去
#include "stdafx.h" // 使用其他IDE请将此行删去
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
// 数组最大长度
#define MAX_LENGTH 23
// 数组初始长度
#define INIT_LENGTH 20
// 数组增长长度
#define INC_LENGTH 3
// 随机数最大值,此处可任意修改
#define MAX_RAND 5555555
// 冒泡排序法
void BubbleSord(int*, int);
// 输出
void Output(int*, int);
int _tmain(int argc, _TCHAR* argv[]) // 使用其他IDE请将_tmain换成main
int i;
int Array[MAX_LENGTH] = 0;
for (i=0; i<INIT_LENGTH; i++)
// 此部分为了防止程序运行过快,种子相同,将种子复杂化
Array[i] = rand() % MAX_RAND;
srand((unsigned int)(time(NULL)*Array[i]));
BubbleSord(Array, INIT_LENGTH);
Output(Array, INIT_LENGTH);
for (i=0; i<INC_LENGTH; i++)
printf("Please enter a new num:");
scanf("%d", &Array[INIT_LENGTH-1+i]); // 减一防止内存溢出
BubbleSord(Array, MAX_LENGTH);
Output(Array, MAX_LENGTH);
return 0;
// 冒泡排序法
void BubbleSord(int* Array, int Length)
int i, j, Temp;
for (i=0; i<Length-1; i++)
for (j=i+1; j<Length; j++)
if (Array[i]>Array[j])
Temp = Array[i];
Array[i] = Array[j];
Array[j] = Temp;
// 输出
void Output(int* Array, int Length)
int i;
for (i=0; i<Length; i++)
printf("%d\n", Array[i]);
参考技术B #include "stdio.h"
main()
int a[23];
int i,j,t,n=0,num[3],g;
for(i=0;i<20;i++)
a[i]=rand();
/*随机产生数组*/
for(i=0;i<20;i++)
for(j=i+1;j<20;j++)
if (a[i]>a[j])
t=a[i];
a[i]=a[j];
a[j]=t;
/*数组排序*/
printf("initial array:\n");
for(i=0;i<20;i++)
if(n==5)
n=0;
printf("\n");
printf("%d ",a[i]);
n=n+1;
/*输出初始化数组*/
printf("\n");
for(i=0;i<3;i++)
printf("please input the number:\n");
scanf("%d",&num[i]);
/*输入三个数字*/
for(i=0;i<3;i++)
for(j=0;j<20+i+1;j++)
if (a[j]>num[i])
break;
for(g=19+i;g>j;g--)
a[g+1]=a[g];
a[j]=num[i];
/*插入三个元素*/
printf("the new array:\n");
for(i=0;i<23;i++)
if(n==5)
n=0;
printf("\n");
printf("%d ",a[i]);
n=n+1;
/*输出新的数组*/
getch();
结果符合,但是由于不是动态分配,有一定的限制性。 参考技术C 写完了,用c++写的,如果想用c的话就把输入输出的函数改一下,相信你能做到。
#include
"stdio.h"
#include
"iostream.h"
#define
num
50
int
arry[num];
//原始数组
int
arry2[num*2];
//修改后数组
int
arry_num=0;
//数组元素个数
int
x=0;
//插入的数值
int
step=0;
//步长
void
arry_input()
//数组输入函数
cout<<"请输入数组元素个数:"<
>arry_num;
for(int
i=1;i
>arry[i];
cout<<"请输入要插入的数值"<
>x;
void
arry_insert()
//数组插入函数
for(int
i=1;i
评论
0
0
加载更多
以上是关于c语言中怎样写a的b次方,高手,请将整个程序写出来。谢谢的主要内容,如果未能解决你的问题,请参考以下文章