C语言5次

若s1=s2,输出0;输出的非零值应该是相比较的两个字符串第一个不相同位置的字符ASCII差值,例如”And”和”Aid”比较,根据第2个字符的比较结果,应输出5。6.给定15个按从小到大已经有序的整数,将其放在一个数组中。另外输入一个整数,要求使用折半查找法找出该数是数组中的第几个元素的值。1.读入两个字符串s1和s2,将s2中的全部字符复制到字符数组s1中去。7.找出一个二维数组中的所有鞍点,即该位置上的元素在该行中最大但是在该列中最小。将一个数组中的值按照原始顺序的逆序重新存放,并输出逆序后的数组。
摘要由CSDN通过智能技术生成

1.读入两个字符串s1和s2,将s2中的全部字符复制到字符数组s1中去。要求不使用strcpy函数,并保证字符串末尾的’\0’标识符同时被赋值。

#include <stdio.h>
void main()
{
   
int i;
char s1[30],s2[30];
gets(s1);
gets(s2);
for(i=0;i<30;i++)
{
   
s1[i]=s2[i];
}
puts(s1);
}

2.读入两个字符串s1和s2,比较这两个字符串。若s1>s2,输出一个正数;若s1=s2,输出0;若s1<s2,输出一个负数。输出的非零值应该是相比较的两个字符串第一个不相同位置的字符ASCII差值,例如”And”和”Aid”比较,根据第2个字符的比较结果,应输出5。
要求不要使用strcpy和strcmp函数。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
   
   char s1[101];
   char s2[101];

   gets(s1);
   gets(s2);

   int long1=strlen(s1);
   int long2=strlen(s2);

   if(long1>long2)
   {
   
       int x;

       for(int i=0;i<long2;i++)
       {
   
           if(s1[i]!=s2[i])
           {
   
               x=abs(s1[i]-s2[i]);
               printf("%d\n",x);
               break;
           }
       }
   }
   else if(long1==long2)
   {
   
       int x=0;

       printf("%d\n",x);
   }
   else if(long1<long2)
   {
   
       int x;

       for(int i=0;i<long1;i++)
       {
   
           if(s1[i]!=s2[i])
           {
   
               x=-abs(s1[i]-s2[i]);
               printf("%d\n",x);
               break;
           }
       }
   }

    return 0;
}

3.有一行电文,已经按照如下规则译成了密码:
A->Z a->z
B->Y b->y
C->X c->x
… …
… …
即第1个字母变换成第26个字母,第i个字母变换成第(26-i+1)个字母。非字母字符不变。给定一段密码,请将其译成原文并输出。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
   
    char s1[101];
    char s2[101];

    gets(s1);

    int longs=strlen(s1);

    for(int i=0;i<longs;i++)
    {
   
        if(s1[i]>='A'&&s1[i]<='Z')
        {
   
            s2[i]='A'+'Z'-s1[i];
        }
        else if(s1[i]>='a'&&s1[i]<='z')
        {
   
            s2[i]='a'+'z'-s1[i];
        }
        else
            s2[i]=s1[i];
    }
    puts(s2);
    return 0;
}

4.输出如下图案:





* * * * *

请使用字符数组的方式完成本题

#include <stdio.h>
#include <stdlib.h>
#define r 15
#define c 15

int main()
{
   
    char chars[r][c]={
    "* * * * *",
                        " * * * * *",
                        "  * * * * *",
                        "   * * * * *",
                        "    * * * * *"};
    for(int i=0;i<r;i++)
    {
   
        printf("%s\n",chars[i
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值