这在C中很容易实现。
一、将A中的数据作为调用函数B的参数,经过B处理后,返回到A。假定A为主函数main(),B为排序函数Sort(int a[],int n),在A中给数组a[]赋值,通过函数B进行排序,完成后返回到A。
#include <stdio.h>#include <stdlib.h>
#include <time.h>
#define MAXlen 100
void Sort(int *x, int n) { //选梁旦手择排序
int i, j, min
int t
for (i = 0 i < n - 1 i++) { // 要选择的次数:0~n-2共n-1次
min = i 迟饥// 假设当前下标为i的数最小,比较后再调整
for (j = i + 1 j < n j++) { //循环找出最小的数的下标是哪个
if (*(x + j) < *(x + min)) {
min = j // 如果后面的数比前面的小,则记下它的下标
}
}
if (min != i) { // 如果橡嫌min在循环中改变了,就需要交换数据
t = *(x + i)
*(x + i) = *(x + min)
*(x + min) = t
}
}
}
int main() {
int i
int iArr[MAXlen]
srand((unsigned int)time(NULL))
printf("\n排序前:\n")
for(i = 0 i < MAXlen i++) {
iArr[i] = (unsigned int)rand() % 1000
if(i % 10 == 0) printf("%\n")
printf("%5d",iArr[i])
}
printf("\n")
Sort(iArr,MAXlen)
printf("\n排序后:\n")
for(i = 0 i < MAXlen i++) {
if(i % 10 == 0) printf("%\n")
printf("%5d",iArr[i])
}
printf("\n\n")
return 0
}
使用库函数 system(), 它的功能正是所要的。注意, 系统返回的值最多是命令的退出状态值 (但这并不是一定的), 通常和命令的输出无关。还要注意,system() 只接受一个单独的字符串参数来表述调用程序。如果要建立复杂的命令行, 可以使用 sprintf()。根弯者早据使用的系统, 也许还可以使用系统函数, 例如exec 或埋雀 spawn (或execl,嫌罩execv, spawnl, spawnv 等)。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)