| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 737 人关注过本帖, 1 人收藏
标题:请大家帮帮我:这道题怎么做?
只看楼主 加入收藏
江爽
Rank: 2
等 级:论坛游民
帖 子:11
专家分:17
注 册:2009-10-14
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:9 
请大家帮帮我:这道题怎么做?
   最近开始学习C语言了,开始学的时候,还觉得挺好学的,但随着知识的加深,进度的加快,我感到有些力不从心了。特别是进来老师布置的作业难度也加大了。昨天的
一个文本串可以用事先给定的字母影射表进行加密,如,该字母影射表为:
a b c d e f g h I j k l m n o p q r s t u v w x y z
q w e r t y u I o p a s d f g h j k l z x c v b n m
则字符串“teacher”被加密为“ztqeitk”,编程实现以下目标:
(1)将输入的文本串进行加密后输出
(2)将输入的加密文本串进行解密后输出


这道题我想了半天还是不会做。我希望通过大家的指点,我的C语言能够进步,学起来相对轻松一些,先谢谢大家了
搜索更多相关主题的帖子: 加密 teacher 字符串 C语言 
2009-10-14 16:26
pgy
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:C
等 级:小飞侠
威 望:8
帖 子:1248
专家分:2329
注 册:2009-9-23
收藏
得分:0 
你们老师究竟是想考“C”还是考找规律?

我可好玩啦...不信你玩玩^_^
2009-10-14 16:36
UserYuH
Rank: 12Rank: 12Rank: 12
来 自:毅华
等 级:火箭侠
威 望:8
帖 子:720
专家分:3300
注 册:2009-8-10
收藏
得分:6 
程序代码:
#include <stdio.h> 
int main(void) 
{ 
 int i,j; 
 char s[200],mi[27]={"qwertyuiopasdfghjklzxcvbnm"}; 
 gets(s); 
 for(i=0;i<strlen(s);i++) 
   { 
    s[i]=s[i]>'Z'?mi[s[i]-'a']:mi[s[i]-'A']-32; 
   } 
 puts(s); 
 getch(); 
 return 0; 
}
输入大小写均可。
如输入:teacher
显示  :ztqeitk
·
如输入:TEACHER
显示  :ZTQEITK

努力—前进—变老—退休—入土
2009-10-14 17:06
LiuQ743
Rank: 2
等 级:论坛游民
帖 子:14
专家分:26
注 册:2009-10-12
收藏
得分:4 
//加密请先输入"+",解密请先输入"!"
#include<stdio.h>
 
void jiami();
void jiemi();
 
void main()
{
    char c=getchar();
    if(c=='!'){
        jiemi();
        printf("\n");}
    else if(c=='+'){
        jiami();
         printf("\n");}
    else  
        printf("加密要先输入“+”,解密要先输入“!”\n");
}
 
void jiami()
{
    int c;
    while((c=getchar())!='\n')
        switch(c){
        case 'a':printf("q");break;
        case 'b':printf("w");break;
        case 'c':printf("e");break;
        case 'd':printf("r");break;
        case 'e':printf("t");break;
        case 'f':printf("y");break;
        case 'g':printf("u");break;
 
        case 'h':printf("i");break;
        case 'i':printf("o");break;
        case 'j':printf("p");break;
        case 'k':printf("a");break;
        case 'l':printf("s");break;
        case 'm':printf("d");break;
        case 'n':printf("f");break;
 
        case 'o':printf("g");break;
        case 'p':printf("h");break;
        case 'q':printf("j");break;
        case 'r':printf("k");break;
        case 's':printf("l");break;
        case 't':printf("z");break;
 
        case 'u':printf("x");break;
        case 'v':printf("c");break;
        case 'w':printf("v");break;
        case 'x':printf("b");break;
        case 'y':printf("n");break;
        case 'z':printf("m");break;
 
        case ' ':printf(" ");break;
}}
 
void jiemi()
{
    int c;
    while((c=getchar())!='\n')
        switch(c){
        case 'a':printf("k");break;
        case 'b':printf("x");break;
        case 'c':printf("v");break;
        case 'd':printf("m");break;
        case 'e':printf("c");break;
        case 'f':printf("n");break;
        case 'g':printf("o");break;
 
        case 'h':printf("p");break;
        case 'i':printf("h");break;
        case 'j':printf("q");break;
        case 'k':printf("r");break;
        case 'l':printf("s");break;
        case 'm':printf("z");break;
        case 'n':printf("y");break;
 
        case 'o':printf("i");break;
        case 'p':printf("j");break;
        case 'q':printf("a");break;
        case 'r':printf("d");break;
        case 's':printf("l");break;
        case 't':printf("e");break;
 
        case 'u':printf("g");break;
        case 'v':printf("w");break;
        case 'w':printf("b");break;
        case 'x':printf("u");break;
        case 'y':printf("f");break;
        case 'z':printf("t");break;
 
        case ' ':printf(" ");break;
}}
2009-10-14 17:13
godbless
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:1
帖 子:216
专家分:950
注 册:2009-7-24
收藏
得分:5 
#include <stdio.h>
 
int main()
{
 char encry[2][26]={{'a','b','c','d','e','f','g','h','i','j','k','l','m',
                     'n','o','p','q','r','s','t','u','v','w','x','y','z'},
                    {'q','w','e','r','t','y','u','i','o','p','a','s','d',
                     'f','g','h','j','k','l','z','x','c','v','b','n','m'}};
 char decry[2][26],string[100];
 int i,j,choose;
 for(i=0;i<26;++i)
    decry[0][i]=decry[1][encry[1][i]-'a']='a'+i;
 printf("请输入字符串:");  
 while(scanf("%s",string)!=EOF)
      {
       printf("你要加密还是解密?1:加密,2:解密\n请输入:");
       scanf("%d",&choose);
       if(choose==1)  
         for(i=0;string[i]!='\0';++i)
            printf("%c",encry[1][string[i]-'a']);
         else
             for(i=0;string[i]!='\0';++i)
            printf("%c",decry[1][string[i]-'a']);
       putchar('\n');
       printf("请再输入字符串:");
      }  
 return 0;
}   
2009-10-14 17:15
LiuQ743
Rank: 2
等 级:论坛游民
帖 子:14
专家分:26
注 册:2009-10-12
收藏
得分:5 
//加密请先输入"+",解密请先输入"!"
#include<stdio.h>
#define MAX 1000
 
void jiami();
void jiemi();
 
void main()
{
    char c=getchar();     
    if(c=='!'){
        jiemi();
        printf("\n");}
    else if(c=='+'){
        jiami();
         printf("\n");}
    else  
        printf("加密要先输入“+”,解密要先输入“!”\n");
}
 
void jiami()
{
    char s[MAX],mi[27]={"qwertyuiopasdfghjklzxcvbnm"};
    int c,i=0;
    while((c=getchar())!='\n')
    {
        s[i]=mi[c-'a'];
        i++;
    }
        for(int j=0;j<i;j++)
            printf("%c",s[j]);
}
 
void jiemi()
{
    char s[MAX],mi[27]={"kxvmcnophqrszyijadlegwbuft"};
    int c,i=0;
    while((c=getchar())!='\n')
    {
        s[i]=mi[c-'a'];
        i++;
    }
        for(int j=0;j<i;j++)
            printf("%c",s[j]);
}
看了3楼的改了下
2009-10-14 17:34
jcslt
Rank: 8Rank: 8
来 自:90-xx.com
等 级:蝙蝠侠
帖 子:251
专家分:975
注 册:2009-10-10
收藏
得分:0 
3楼的高手啊,崇拜中》》》

www.
2009-10-14 18:51
pgy
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:C
等 级:小飞侠
威 望:8
帖 子:1248
专家分:2329
注 册:2009-9-23
收藏
得分:0 
向User学习!
我没懂题意= =!还以为是找出加密和解密码的对应关系,然后通过对应关系写代码
数学做多了...

我可好玩啦...不信你玩玩^_^
2009-10-14 19:00
江爽
Rank: 2
等 级:论坛游民
帖 子:11
专家分:17
注 册:2009-10-14
收藏
得分:0 
谢谢大家,三楼的高手给我的解法时间复杂度虽然小,但我没有看懂,还是谢谢了。其他的朋友时间复杂度有些大,都谢谢啦,我会努力的
2009-10-17 17:20
快速回复:请大家帮帮我:这道题怎么做?
数据加载中...
 
   



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

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