|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- #include <stdio.h>
- #include <string.h>
- void input(int num[10],char name[10][10]);
- void output(int num[10],char name[10][10]);
- void sort(int num[10],char name[10][10]);
- int main(){
- int num[10];
- char name[10][10];
- input(num,name);
- printf("\n");
- output(num,name);
- sort(num,name);
- printf("排序后:\n");
- output(num,name);
- }
- void input(int num[10],char name[10][10]){
- for(int i=0;i<10;i++){
- printf("请输入第%d个职工的编号:",i+1);
- scanf("%d",&num[i]);
- getchar();
- printf("请输入第%d个职工的姓名:",i+1);
- gets(name[i]);
- }
- }
- void output(int num[10],char name[10][10]){
- for(int i=0;i<10;i++){
- printf("编号%d,姓名:%s\n",num[i],name[i]);
- }
- }
- void sort(int num[10],char name[10][10]){
- for(int i=0;i<9;i++){
- for(int j=0;j<9-i;j++){
- if(num[i]>num[i+1])
- {
- int temp=num[i];
- num[i] = num[i+1];
- num[i+1] = temp;
- char string[10];
- strcpy(string,name[i]);
- strcpy(name[i],name[i+1]);
- strcpy(name[i+1],string);
- }
- }
- }
- }
复制代码
排序后的输出并不是由小到大的
你的冒泡排序算法出现了问题。在你的sort函数中,你使用了两个嵌套的for循环来比较和交换元素,但是在比较和交换元素的地方有一些错误。
首先,你的比较条件应该是 num[j] > num[j+1] ,而不是 num[ i] > num[i+1] 。这是因为你正在使用j来遍历数组,而不是i。
其次,在交换元素的地方,你需要使用j而不是i。所以你的交换代码应该是这样的:
- if(num[j] > num[j+1]) {
- int temp = num[j];
- num[j] = num[j+1];
- num[j+1] = temp;
- char string[10];
- strcpy(string, name[j]);
- strcpy(name[j], name[j+1]);
- strcpy(name[j+1], string);
- }
复制代码
通过这些修改,你的冒泡排序算法应该能够正确地对编号进行排序。
|
|