C语言编程题目 对已知整数数组a[]的元素按从小到大的顺序连续编号(即,值相同的元素有相同编号),
来源:学生作业帮 编辑:作业帮 分类:综合作业 时间:2024/11/08 21:38:29
C语言编程题目 对已知整数数组a[]的元素按从小到大的顺序连续编号(即,值相同的元素有相同编号),
对已知整数数组a[]的元素按从小到大的顺序连续编号(即,值相同的元素有相同编号),并将编号保存在数组b[]中.即,a[i]的编号为b[i].要求:1)用指针数组实现;2)数组a的元素随机生成(值
对已知整数数组a[]的元素按从小到大的顺序连续编号(即,值相同的元素有相同编号),并将编号保存在数组b[]中.即,a[i]的编号为b[i].要求:1)用指针数组实现;2)数组a的元素随机生成(值
//思路:用指针数组进行排序,保存排序后的下标到c中.即a[c[0:N-1]]是升序的
// 然后依次比较c[i]为下标的有序数组a[c[0:N-1]]的各元素,进行顺序编号
/*
对已知整数数组a[]的元素按从小到大的顺序连续编号(即:值相同的元素有相同编号),
并将编号保存在数组b[]中. 即, a[i]的编号为b[i]. 要求:
1)用指针数组实现;
2)数组a的元素随机生成(值<10).
*/
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define N 10
void printIntArr(int a[], int n);//打印整型跟数组a的前n个值
//交换两个int*型指针的值
void swap2intPointer(int **x, int **y){
int *temp = *x;//*x是int *型指针
*x = *y;
*y = temp;
};
void swap2int(int *x, int *y){
int temp = *x;
*x = *y;
*y = temp;
};
int main()
{
srand(time(NULL));
int i=0,j=0, k=0;
int a[N]={},b[N]={},c[N]={};;
int *p[N]={NULL};
int flag=1;//1表示有交换
//生成数组,并初始化指针数组
for(int i=0;i<N;i++)
{
a[i]=rand()%10;
c[i]=i;
p[i]=a+i;
}
printf("原始数组为:\n");
printIntArr(a,N);
//对指针数组进行排序,使得指针数组对应中元素指向的数据依次上升
for(i=0;flag&&i<N-1;i++)
{
flag=0;//默认没有交换.这样在排好序时可以结束排序算法.
for( j=0;j<N-i-1;j++)
{
if(*p[j] >*p[j+1])
{
swap2intPointer(&p[j],&p[j+1]);
swap2int(c+j,c+j+1);
flag=1;
}
}
}
//printf("排序后:\n");
//for(i=0;i<N;i++)
//{
//printf("%3d ",*p[i]);
//}
//puts("\n");
/*i=0,j=0;
printf("排序后的下标:\n");
for(i=0;i<N;i++)
{
printf("%3d ",c[i]);
}
puts("\n");*/
//最后一步:进行记录
i=0;
j=1;
while(i<N-1)
{
while(i<N-1 && a[c[i]]==a[c[i+1]])
{
b[c[i]]=j;
i++;
}
b[c[i]]=j++;
i++;
}
if(a[c[N-2]]!=a[c[N-1]])
b[c[N-1]]=j;
//打印数组元素大小编号
printf("原来数组元素的大小编号:\n");
for(i=0;i<N;i++)
{
printf("%3d ",b[i]);
}
puts("\n");
return 0;
}
//打印整型数组a的前元素
void printIntArr(int a[], int n)
{
if(n<=0) return;
for(int i=0;i<n;i++)
printf("%3d ", a[i]);
putchar('\n');
return;
}
// 然后依次比较c[i]为下标的有序数组a[c[0:N-1]]的各元素,进行顺序编号
/*
对已知整数数组a[]的元素按从小到大的顺序连续编号(即:值相同的元素有相同编号),
并将编号保存在数组b[]中. 即, a[i]的编号为b[i]. 要求:
1)用指针数组实现;
2)数组a的元素随机生成(值<10).
*/
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define N 10
void printIntArr(int a[], int n);//打印整型跟数组a的前n个值
//交换两个int*型指针的值
void swap2intPointer(int **x, int **y){
int *temp = *x;//*x是int *型指针
*x = *y;
*y = temp;
};
void swap2int(int *x, int *y){
int temp = *x;
*x = *y;
*y = temp;
};
int main()
{
srand(time(NULL));
int i=0,j=0, k=0;
int a[N]={},b[N]={},c[N]={};;
int *p[N]={NULL};
int flag=1;//1表示有交换
//生成数组,并初始化指针数组
for(int i=0;i<N;i++)
{
a[i]=rand()%10;
c[i]=i;
p[i]=a+i;
}
printf("原始数组为:\n");
printIntArr(a,N);
//对指针数组进行排序,使得指针数组对应中元素指向的数据依次上升
for(i=0;flag&&i<N-1;i++)
{
flag=0;//默认没有交换.这样在排好序时可以结束排序算法.
for( j=0;j<N-i-1;j++)
{
if(*p[j] >*p[j+1])
{
swap2intPointer(&p[j],&p[j+1]);
swap2int(c+j,c+j+1);
flag=1;
}
}
}
//printf("排序后:\n");
//for(i=0;i<N;i++)
//{
//printf("%3d ",*p[i]);
//}
//puts("\n");
/*i=0,j=0;
printf("排序后的下标:\n");
for(i=0;i<N;i++)
{
printf("%3d ",c[i]);
}
puts("\n");*/
//最后一步:进行记录
i=0;
j=1;
while(i<N-1)
{
while(i<N-1 && a[c[i]]==a[c[i+1]])
{
b[c[i]]=j;
i++;
}
b[c[i]]=j++;
i++;
}
if(a[c[N-2]]!=a[c[N-1]])
b[c[N-1]]=j;
//打印数组元素大小编号
printf("原来数组元素的大小编号:\n");
for(i=0;i<N;i++)
{
printf("%3d ",b[i]);
}
puts("\n");
return 0;
}
//打印整型数组a的前元素
void printIntArr(int a[], int n)
{
if(n<=0) return;
for(int i=0;i<n;i++)
printf("%3d ", a[i]);
putchar('\n');
return;
}
C语言编程题目 对已知整数数组a[]的元素按从小到大的顺序连续编号(即,值相同的元素有相同编号),
一道C语言的题目(1) 对数组A中的N(0<N<100)个整数从小到大进行连续编号,要求不能改变数
C语言 【给数组中的元素按顺序编号】
C语言程序编程5. 给定一个一维数组a有N个元素,求最大值。6. 用选择法对10个数按从小到大的顺序排列。7. 有一个3
已知长度为n的数组的元素为整数,编程将数组中的偶数从小到大排序,奇数位置不变.
C语言中,寻找两个数组中相同的元素的个数,与元素
在整数数组a[20]中找出偶数放在b数组中,对b数组按从小到大的顺序进行排序后,按每行3个元素输出.
C语言编程:用一个数组表示一个正整数,一个数组元素表示整数的一位,例如396可以用数组表示
C语言 下列对数组a 数组元素正确的引用形式是
已知一个数组中的元素按元素值非递减有序排列,编写一个函数删除数组中多余的值相同的元素
在c语言中,int a[10]表示a是一个整数有10个元素的数组?
元素周期表原子序数按元素原子的什么递增顺序给元素编号,且原子序数等于什么等于什么