| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 667 人关注过本帖
标题:问两道题
只看楼主 加入收藏
灬xiaoning
Rank: 2
等 级:论坛游民
帖 子:27
专家分:10
注 册:2010-7-24
结帖率:75%
收藏
 问题点数:0 回复次数:6 
问两道题
   循环打印输出图形
    *
    ***
    ******
    ********
    ******
    ***
    *


   编写一个程序,当输入不超过60个字符组成的英文文字时,计算机将这个句子 中的字母按英文字典字母顺序重新排列,排列后的单词的长度要与原始句子中的长度相同。例如:

    输入:

    THE PRICE OFBREAD IS ¥1 25 PER POUND

    输出:

    ABC DDEEE EFHIINO OP ¥1 25 PPR RRSTU
搜索更多相关主题的帖子: 字母 计算机 英文字典 
2010-07-24 07:59
vs_inzaghi
Rank: 5Rank: 5
来 自:湖北
等 级:职业侠客
威 望:1
帖 子:303
专家分:364
注 册:2009-8-17
收藏
得分:0 
第一题就算了
第二题,我给了一个很笨但是很好写的算法……
程序如下:(在TC上编译通过)
#include<stdio.h>
#include<string.h>
void main()
{
 char array_a[61],array_b[61],array_c[61];
 int i,j,temp,count;
 count=0;
 printf("please input your words\n");
 gets(array_a);
 for(i=0;i<strlen(array_a);i++)
 {
  if((array_a[i]>64&&array_a[i]<91)||(array_a[i]>96&&array_a[i]<123))
  {
   array_c[count]=array_a[i];
   count++;
  }
  else
  continue;
 }
 for(j=0;j<count-1;j++)
 for(i=0;i<count-1-j;i++)
 {
  if(array_c[i]>array_c[i+1])
  {
   temp=array_c[i];
   array_c[i]=array_c[i+1];
   array_c[i+1]=temp;
  }
 }
 j=0;
 for(i=0;i<strlen(array_a);i++)
 {
  if((array_a[i]>64&&array_a[i]<91)||(array_a[i]>96&&array_a[i]<123))
  {
   array_b[i]=array_c[j];
   j++;
  }
  else
  array_b[i]=array_a[i];
 }
 printf("the words your input is:\n");
 printf("%s\n",array_b);
}

我很懒,但我讨厌别人说我懒……
2010-07-24 09:36
灬xiaoning
Rank: 2
等 级:论坛游民
帖 子:27
专家分:10
注 册:2010-7-24
收藏
得分:0 
回复 2楼 vs_inzaghi
谢谢啊
唉 还有道题
帮我一下 可以吗
2010-07-24 12:05
erikyo
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:270
专家分:1154
注 册:2010-6-10
收藏
得分:0 
#include <stdio.h>

int main()
{
    int i = 0;
    int j = 0;
    for(i = 0 ; i < 4 ; i++)
    {
        for(j = 0 ; j < 2*i+1; j++)
            printf("*");
        printf("\n");
    }

    for(i = 3 ; i > 0 ; i--)
    {
        for(j = 0 ; j < 2*i-1 ; j++)
            printf("*");
        printf("\n");
    }
    return 0;
}
方法虽然比较土,但是功能还是完成了~
2010-07-24 12:30
蚊丨子
Rank: 2
等 级:论坛游民
帖 子:11
专家分:24
注 册:2010-7-9
收藏
得分:0 
第一道我就不做了...发个第二题的...
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
#define N 100

void f(char *p)
{
    char *p1,temp;

    for (; *p != '\0'; p++)
    {
        if (isalpha(*p))
        {
            for (p1 = p + 1; *p1 != '\0'; p1++)
            {
       
                    if (*p > *p1)
                    {
                        if (isdigit(*p1))
                        {
                            continue;
                        }
                        else
                        {
                            temp = *p;
                            *p = *p1;
                            *p1 = temp;
                        }
                    }
            }
        }
        else
        {
            ++p;
        }
    }
}

int main()
{
    char a[N];

    scanf("%s",a);
    f(a);
    printf("%s",a);
    return EXIT_SUCCESS;
}

2010-07-24 21:46
a279742336
Rank: 2
等 级:论坛游民
帖 子:36
专家分:24
注 册:2010-7-20
收藏
得分:0 
main()
{
int i,j,k;
for(i=0;i<=3;i++)
 {
 for(j=0;j<=2-i;j++)
  printf(" ");
 for(k=0;k<=2*i;k++)
  printf("*");
 printf("\n");
 }
for(i=0;i<=2;i++)
 {
 for(j=0;j<=i;j++)
  printf(" ");
 for(k=0;k<=4-2*i;k++)
  printf("*");
 printf("\n");
 }
}


我也是刚学   不知对否
收到的鲜花
  • 灬xiaoning2010-08-01 08:43 送鲜花  2朵  
2010-07-27 23:09
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
第二道题,解释比较详细,LZ仔细看看
#include <stdio.h>
#include <string.h>
void Sort(char* str) //str是一个一级指针,接收数组的第一个元素
{
for(int i=0;i<4;i++) //利用冒泡排序方法
{
for(int j=i;j<5;j++)
{
char* pre=new char[50];
char*next=new char[50];
pre=str+50*i; //由于你申请数组的时候,每个数组大小为50,所以每个元素的偏移量为50
next=str+50*j;
if(strcmp(pre,next)>0)//比较
{
char temp[50];
strcpy(temp,pre);//交换
strcpy(pre,next);//交换
strcpy(next,temp);//交换
}
}
}
}
void main()
{
char str[5][50];
for(int i=0;i<5;i++)
scanf("%s",*(str+i));//输入字符串
Sort(str[0]); //此处将数组的第一个元素传过去
for(int k=0;k<5;k++) //输出,如果此处也需要调用函数的话,仿照上述方法即可
{
printf("%s\t",str[k]);
}
printf("\n");
}
收到的鲜花
  • 灬xiaoning2010-08-01 08:43 送鲜花  2朵  

欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-07-28 10:14
快速回复:问两道题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.013517 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved