鱼C论坛

 找回密码
 立即注册
查看: 1072|回复: 4

[已解决]接上一次的C++问题

[复制链接]
发表于 2020-3-4 17:11:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 ttyule1 于 2020-3-4 18:28 编辑

1.从键盘上输入两个整数,编程进行交换二者的值,要求定义chang函数,函数形参使用引用类型。
2.从键盘上输入5个整数,并将5个数按照从小到大输出。要求定义排序函数sort,用sort调用chang函数实现排序,形参使用引用类型。
以下是我写的change函数,怎么用我写的change函数来解决第二题呢?
void change(int &num1, int &num2){
        int temp;
        temp = num1;
        num1 = num2;
        num2 = temp;
}
关于这个题的形参要求全部用引用类型的,不能用指针类型
最佳答案
2020-3-4 21:09:36
#include <iostream>
using namespace std;

#define N 100

void change(int &num1, int &num2){
        int temp;
        temp = num1;
        num1 = num2;
        num2 = temp;
}

void sort(int p[], int n)
{
        int i, j;

        for (i = 0; i < (n-1); i++)
        {
                for (j = i+1; j < n; j++)
                {
                        if (p[i] > p[j])
                        {
                                change(p[i], p[j]);
                        }
                }
        }
}


void main ()
{
    int a[50];
    int n, i;

    cout<<"请输入要排序的个数:"<<endl;
    cin>>n;

    if (n > N)
    {
                cout<<"错误:个数超过了"<<N<<"个"<<endl;
                return;
        }

        for(i = 0; i < n; i++)
        {
                cout<<"请输入第"<< i+1<<"个数:"<<endl;
                cin>>a[i];
        }
        //fflush(stdin);

        sort(a, n);

    for(i = 0; i < n; i++)
        {
                cout<<"第"<<i+1<<"个数"<<a[i]<<endl;;
        }

        return;      
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-4 20:15:29 | 显示全部楼层
本帖最后由 Cool_Breeze 于 2020-3-4 20:16 编辑

看看这个是不是!我查了一下,不知道对不对!(对C++不了解)
#include <stdio.h>
void sort(int (&p)[5]);
void swap(int &num1,int &num2);
int main(void)
{
        int arr[5];
        int i,j;
        for (i=0;i<5;i++)
        {
                printf("请输入第%d个数:\n",i+1);
                scanf("%d",&arr[i]);
        }
        for (i=0;i<5;i++) printf("%8d",arr[i]);
        sort(arr);
        printf("\nsorted\n");
        for (i=0;i<5;i++) printf("%8d",arr[i]);
        return 0;
}
void swap(int &num1,int &num2)
{
    int temp;
    temp = num1;
    num1 = num2;
        num2 = temp;
}
void sort(int (&p)[5])
{
        int i,j;
        for (i=0;i<5-1;i++)
        {
                for (j=i+1;j<5;j++)
                {
                        if (p[j]<p[i])
                        swap(p[j],p[i]);
                }
        }
        
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-4 20:36:50 | 显示全部楼层
本帖最后由 alexw_h264 于 2020-3-4 20:38 编辑

#include <stdio.h>
#define N 100

void change(int &num1, int &num2){
        int temp;
        temp = num1;
        num1 = num2;
        num2 = temp;
}

void sort(int p[], int n)
{
        int i, j;

        for (i = 0; i < (n-1); i++)
        {
                for (j = i+1; j < n; j++)
                {
                        if (p[i] > p[j])
                        {
                                change(p[i], p[j]);
                        }
                }
        }
}


void main ()
{
    int a[50];
    int n, i;

    printf("请输入要排序的个数:");
    scanf("%d", &n);

    if (n > N)
    {
                printf("错误:个数超过了%d个.\n", N);
                return;
        }

        for(i = 0; i < n; i++)
        {
                printf("请输入第 %d 个数:", i + 1);
                scanf("%d", &a[i]);
        }
        fflush(stdin);

        //change(a[0], a[2]);
        sort(a, n);

    for(i = 0; i < n; i++)
        {
                printf("第 %d 个数:%d\n", i+1, a[i]);
        }

        return;      
}

验证结果:
请输入要排序的个数:5
请输入第 1 个数:100
请输入第 2 个数:98
请输入第 3 个数:101
请输入第 4 个数:70
请输入第 5 个数:67
第 1 个数:67
第 2 个数:70
第 3 个数:98
第 4 个数:100
第 5 个数:101
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-3-4 20:40:04 | 显示全部楼层

您好,是用c++,不是c
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-4 21:09:36 | 显示全部楼层    本楼为最佳答案   
#include <iostream>
using namespace std;

#define N 100

void change(int &num1, int &num2){
        int temp;
        temp = num1;
        num1 = num2;
        num2 = temp;
}

void sort(int p[], int n)
{
        int i, j;

        for (i = 0; i < (n-1); i++)
        {
                for (j = i+1; j < n; j++)
                {
                        if (p[i] > p[j])
                        {
                                change(p[i], p[j]);
                        }
                }
        }
}


void main ()
{
    int a[50];
    int n, i;

    cout<<"请输入要排序的个数:"<<endl;
    cin>>n;

    if (n > N)
    {
                cout<<"错误:个数超过了"<<N<<"个"<<endl;
                return;
        }

        for(i = 0; i < n; i++)
        {
                cout<<"请输入第"<< i+1<<"个数:"<<endl;
                cin>>a[i];
        }
        //fflush(stdin);

        sort(a, n);

    for(i = 0; i < n; i++)
        {
                cout<<"第"<<i+1<<"个数"<<a[i]<<endl;;
        }

        return;      
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-15 23:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表