鱼C论坛

 找回密码
 立即注册
查看: 2707|回复: 21

[技术交流] 每日一练—基础题

[复制链接]
发表于 2015-1-16 09:49:53 | 显示全部楼层 |阅读模式

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

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

x
1   问题描述
  给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
  第一行为一个整数n
  第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000
输出格式
  输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9

评分

参与人数 1荣誉 +5 鱼币 +10 贡献 +5 收起 理由
康小泡 + 5 + 10 + 5 楼主不错。顶一个。加油哇 么么哒

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2015-1-16 19:49:23 | 显示全部楼层
顶楼主~
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-17 11:56:19 | 显示全部楼层

#include <stdio.h>
void main()
{
    int i,j,n,temp;
    int a[199];//定义一个200的数组a
    printf("请输入n:\n");
    scanf("%d",&n);//输入n的值
    for(i=0;i<n;i++)//输入n个整数
    {
        printf("输入第%d个数\n",i+1);
        scanf("%d",&a[i]);
    }

    for(i=0;i<n;i++)//选择排序
    {     
        for(j=i;j<n;j++)                     
        {
            if(a[i]>a[j])
            { temp=a[i];
            a[i]=a[j];
            a[j]=temp;
            }
        }
    }
    printf("结果为");

    for(i=0;i<n;i++)//打印结果
    {

        printf("%d   ",a[i]);

    }   
    printf("\n");
}



运行结果

运行结果
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2015-1-17 12:37:18 | 显示全部楼层
ANDES 发表于 2015-1-17 11:56
#include
void main()
{

能否不要预先设定数组大小,而是根据输入n的大小自动生成数组呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-17 14:14:34 | 显示全部楼层
雪是梅之香 发表于 2015-1-17 12:37
能否不要预先设定数组大小,而是根据输入n的大小自动生成数组呢?

不可以,定义数组A[N],这个N不能是变量。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-17 14:17:54 | 显示全部楼层
ANDES 发表于 2015-1-17 14:14
不可以,定义数组A[N],这个N不能是变量。

如果不清楚可以去看小甲鱼的C语言视频,第六章数组第一节就有说明。
QQ截图20150117141853.jpg
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-1-17 14:55:18 | 显示全部楼层
ANDES 发表于 2015-1-17 14:17
如果不清楚可以去看小甲鱼的C语言视频,第六章数组第一节就有说明。

可以用自定义函数啊,在主函数中确定n,将n进行传参,这样不可以吗
附上我写的程序:
排序其实可以更好一点:
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void creat(int *p,int n)
  4. {
  5.     int i;
  6.     for(i=0;i<n;i++)
  7.     {
  8.         scanf("%d",p+i);

  9.     }
  10. }
  11. void Sort(int *p,int n)
  12. {
  13.     int i,j,temp;
  14.     for(j=0;j<n;j++)
  15.     {
  16.         for(i=0;i<n-1;i++)
  17.         {
  18.             if(*(p+i)>*(p+(i+1)))
  19.             {
  20.                 temp=*(p+i);
  21.                 *(p+i)=*(p+(i+1));
  22.                 *(p+(i+1))=temp;
  23.             }
  24.         }
  25.     }

  26. }
  27. void main()
  28. {
  29.     int n;
  30.     int i;
  31.     int *num;
  32.     printf("请输入一个整数:\n");
  33.     scanf("%d",&n);
  34.     printf("请输入%d个整数\n",n);
  35.     num=(int*)malloc(sizeof(int)*n);
  36.     creat(num,n);
  37.     printf("进行排序后是:\n");
  38.     Sort(num,n);
  39.     for(i=0;i<n;i++)
  40.     {
  41.         printf("%d   ",num[i]);
  42.     }
  43. }
复制代码
QQ截图20150117145639.png

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +5 收起 理由
康小泡 + 5 + 5 + 5 支持楼主!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-17 15:12:53 | 显示全部楼层
本帖最后由 ANDES 于 2015-1-17 15:19 编辑
雪是梅之香 发表于 2015-1-17 14:55
可以用自定义函数啊,在主函数中确定n,将n进行传参,这样不可以吗
附上我写的程序:
排序其实可以更好 ...

好吧,既然你的可以就可以咯,反正我也是刚学的,C语言是那么博大精深的。但还是感觉我自己写的代码比较容易懂。:lol::lol:  你用的是自己定义的函数,我用的是数组,数组是不能动态定义大小的,所以我还是对的。我们都少了对n值大小的判断。。。。再加上这个就完美了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-17 23:36:36 From FishC Mobile | 显示全部楼层
。。。c语言 要重学呀
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-1-17 23:39:01 | 显示全部楼层
907806863 发表于 2015-1-17 23:36
。。。c语言 要重学呀

确实很重要啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-19 22:18:27 | 显示全部楼层
可以用链表实现
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-1-19 22:21:55 | 显示全部楼层

怎么实现,没想过,可否写出代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-19 22:38:54 | 显示全部楼层
链表在这个场合应用相当于定义一个长度可变化的数组
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-20 15:47:07 | 显示全部楼层
学习,求鱼币:lol:
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-21 17:17:39 | 显示全部楼层
ANDES 发表于 2015-1-17 11:56
#include
void main()
{

就是那个你定义的a[199]其实只有199的大小 没有200个的大小 想要有200的大小的定义应该是a[200]
数组这里是有一点区别的。  
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-21 17:19:44 | 显示全部楼层
ANDES 发表于 2015-1-17 15:12
好吧,既然你的可以就可以咯,反正我也是刚学的,C语言是那么博大精深的。但还是感觉我自己写的代码比较 ...

大家相互学习  不错哇。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-21 19:20:43 | 显示全部楼层
kklloo 发表于 2015-1-21 17:17
就是那个你定义的a[199]其实只有199的大小 没有200个的大小 想要有200的大小的定义应该是a[200]
数组这 ...

记错了,以为跟内存的一样。感谢提醒。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-21 19:34:26 | 显示全部楼层
ANDES 发表于 2015-1-21 19:20
记错了,以为跟内存的一样。感谢提醒。

不客气的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-21 22:48:34 | 显示全部楼层
本帖最后由 Mr.屎壳螂 于 2015-1-21 22:51 编辑

哈哈~看到题目写一个~~
  1. #include<stdio.h>
  2. #include<stdlib.h>

  3. int px(int *a)
  4. {
  5.         int i,j;
  6.         int temp;
  7.         for(i=1;i<a[0];i++)
  8.         {
  9.                 for(j=1;j<=a[0]-i;j++)
  10.                 {
  11.                         if(a[j]>a[j+1])
  12.                         {
  13.                            temp=a[j+1];
  14.                            a[j+1]=a[j];
  15.                            a[j]=temp;
  16.                         }
  17.                 }
  18.         }
  19.         return 0;
  20. }

  21. int main()
  22. {
  23.         int i,n,*a;
  24.         scanf("%d",&n);
  25.         a=(int*)malloc((n+1)*sizeof(int));
  26.         a[0]=n;
  27.         for(i=1;i<=n;i++)
  28.         {
  29.                 scanf("%d",&a[i]);
  30.         }
  31.         px(a);
  32.         for(i=1;i<=n;i++)
  33.         {
  34.                 printf("%d ",a[i]);
  35.         }
  36.         printf("\n");
  37.         return 0;
  38. }
复制代码


冒泡排序~


小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-1-24 15:53:10 | 显示全部楼层
真心不错
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-13 21:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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