81------90

81public class test {
    public static void main(String[] args){
        //以下是输入整个数组
        int n;
        int array[];
        System.out.println("请输入整数的个数");
        Scanner keyboard=new Scanner(System.in);
        n=keyboard.nextInt();
        array = new int[n];
        for (int i = 0; i < n; i++) {
            System.out.print("输入第" + (i + 1) + "个数据");
            array[i] = keyboard.nextInt();
        }
        System.out.print("你输入的数组为:");
        for(int i=0;i<n;i++) {
            System.out.print(array[i] + " ");
        }
        System.out.print("\n请输入向后移动的位数:");
        int m = keyboard.nextInt();
        int[] b = new int[m];
        for(int i=0; i<m; i++) {
            b[i] = array[n-m+i];
        }
        for(int i=n-1; i>=m; i--) {
            array[i] = array[i-m];
        }
        for(int i=0; i<m; i++) {
            array[i] = b[i];
        }
        System.out.print("位移后的数组是:");
        for(int i=0; i<n; i++) {
            System.out.print(array[i] + " ");
        }
    }
}
82

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

//有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
int main()
{
    int a[100];
    int num;int i;
    printf("请输入已经排序好的数组!\n");
    for ( i=0;i<5;i++){
        scanf("%d",&a[i]);
    }
    printf("请输入要插入的数!\n");
    scanf("%d",&num);
    if(a[0]>a[1]){     //如果是降序 
        for(int j=0;j<5;j++){
            if (a[j]<=num){
            int  temp1=a[j];
                 a[j]=num;
      for(int k=j+1;k<6;k++)
         { int temp2=a[k];
             a[k]=temp1;
              temp1=temp2;
}
break;
            }
        }

    }
    else if(a[0]<a[1]){  //  如果是升序 
      for(int j=0;j<5;j++){
            if (a[j]>num){
            int  temp1=a[j];
                 a[j]=num;
      for(int k=j+1;k<6;k++)
             { int temp2=a[k];
                 a[k]=temp1;
                  temp1=temp2;
                               }
                      break;     //(编程错误) 
            }
        } 
    }
for(i=0;i<6;i++)
printf("%6d",a[i]);
    return 0;
}

83.

#include

#include

void main()

{ char c;

printf("请输入第一个字母");

while((c=getche())!=0)

{printf("\n");

switch(c)

{ case 'M':printf("星期一\n");break;

case 'm':printf("星期一y\n");break;

case 'T':printf("请输入第二个字母");

if((c=getche())=='u'||'U') printf("星期二\n");

else if((c=getche())=='h'||'H') printf("\n星期四\n");

else printf("data error\n");

break;

case 't':printf("请输入第二个字母");

if((c=getche())=='u'||'U') printf("\n星期二\n");

else if((c=getche())=='h'||'H') printf("\n星期四\n");

else printf("data error\n");

break;

case 'W':printf("\n星期三");break;

case 'w':printf("星期三");break;

case 'F':printf("星期五\n");break;

case 'f':printf("星期五\n");break;

case 'S':printf("请输入第二个字母");

if((c=getche())=='U'||'u') printf("\n星期天\n");

else if((c=getche())=='a'||'A') printf("\n星期六\n");

else printf("输入错误\n");

break;

case 's':printf("请输入第二个字母");

if((c=getche())=='u'||'U') printf("\n星期天\n");

else if((c=getche())=='a'||'A') printf("\n星期六\n");

else printf("输入错误\n");

break;

default:printf("输入错误");break;

}

}

84.不会做

85.不会做

86.#include <stdio.h> 
 
//利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
void dayin(int i,char *p)
{
    if(i==0)
    {
        printf("%c",p[i]);
        return ;
    }
    else
    {
        printf("%c",p[i]);//第5位是结束符,第4位才是hello的o 
        dayin(i-1,p);
    }
    
}
 
int main()
{
 
    char str[6];//输入5个字符+1个结束符,共6个元素 
    printf("input a string:");//输入hello 
    fgets(str,6,stdin);//6个而不是5个 
    dayin(4,str);
 
}

87.

def fact(j):
    if j == 0:
        sum = 1
    else:
        sum = j * fact(j - 1)
    return sum

print(fact(3))
88。#include <stdio.h>
 
int g(int x)
{
    return x * x - 550;
}
 
int f(int x)
{
    int g_x = g(x);
 
    if (x < g_x)
        return g_x + x + 4;
    else
        return g_x - x;
}
 
int main()
{
    int x;
 
    scanf("%d", &x);
    printf("%d\n", f(x));
 
    return 0;
}

89--90不会做

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是ASP语言中计算SHA-256散列值的算法实现代码: ```asp ' SHA-256 hash function for ASP Function sha256(str) ' 初始化常量 Dim K(64) K(1) = &H428A2F98 K(2) = &H71374491 K(3) = &HB5C0FBCF K(4) = &HE9B5DBA5 K(5) = &H3956C25B K(6) = &H59F111F1 K(7) = &H923F82A4 K(8) = &HAB1C5ED5 K(9) = &HD807AA98 K(10) = &H12835B01 K(11) = &H243185BE K(12) = &H550C7DC3 K(13) = &H72BE5D74 K(14) = &H80DEB1FE K(15) = &H9BDC06A7 K(16) = &HC19BF174 K(17) = &HE49B69C1 K(18) = &HEFBE4786 K(19) = &HFC19DC6 K(20) = &H240CA1CC K(21) = &H2DE92C6F K(22) = &H4A7484AA K(23) = &H5CB0A9DC K(24) = &H76F988DA K(25) = &H983E5152 K(26) = &HA831C66D K(27) = &HB00327C8 K(28) = &HBF597FC7 K(29) = &HC6E00BF3 K(30) = &HD5A79147 K(31) = &H6CA6351 K(32) = &H14292967 K(33) = &H27B70A85 K(34) = &H2E1B2138 K(35) = &H4D2C6DFC K(36) = &H53380D13 K(37) = &H650A7354 K(38) = &H766A0ABB K(39) = &H81C2C92E K(40) = &H92722C85 K(41) = &HA2BFE8A1 K(42) = &HA81A664B K(43) = &HC24B8B70 K(44) = &HC76C51A3 K(45) = &HD192E819 K(46) = &HD6990624 K(47) = &HF40E3585 K(48) = &H106AA070 K(49) = &H19A4C116 K(50) = &H1E376C08 K(51) = &H2748774C K(52) = &H34B0BCB5 K(53) = &H391C0CB3 K(54) = &H4ED8AA4A K(55) = &H5B9CCA4F K(56) = &H682E6FF3 K(57) = &H748F82EE K(58) = &H78A5636F K(59) = &H84C87814 K(60) = &H8CC70208 K(61) = &H90BEFFFA K(62) = &HA4506CEB K(63) = &HBEF9A3F7 K(64) = &HC67178F2 ' 初始化变量 Dim H0, H1, H2, H3, H4, H5, H6, H7 H0 = &H6A09E667 H1 = &HBB67AE85 H2 = &H3C6EF372 H3 = &HA54FF53A H4 = &H510E527F H5 = &H9B05688C H6 = &H1F83D9AB H7 = &H5BE0CD19 ' 对输入字符串进行预处理 Dim M(64) Dim L, N L = Len(str) N = ((L + 8) \ 64 + 1) * 64 ReDim M(N) Dim i, j, k For i = 0 To L - 1 M(i) = Asc(Mid(str, i + 1, 1)) Next M(L) = &H80 M(N - 8) = L * 8 Mod &H100000000 M(N - 7) = L * 8 \ &H100000000 ' 处理每个512位的消息块 Dim W(64), a, b, c, d, e, f, g, h, T1, T2 For i = 0 To N \ 64 - 1 ' 将消息块划分为16个32位字 For j = 0 To 15 k = i * 64 + j * 4 W(j) = M(k) * &H1000000 + M(k + 1) * &H10000 + M(k + 2) * &H100 + M(k + 3) Next ' 扩展16个字为64个字 For j = 16 To 63 W(j) = sigma1(W(j - 2)) + W(j - 7) + sigma0(W(j - 15)) + W(j - 16) Next ' 初始化哈希值 a = H0 b = H1 c = H2 d = H3 e = H4 f = H5 g = H6 h = H7 ' 进行64轮操作 For j = 0 To 63 T1 = h + Sigma1(e) + Ch(e, f, g) + K(j + 1) + W(j) T2 = Sigma0(a) + Maj(a, b, c) h = g g = f f = e e = d + T1 Mod &H100000000 d = c c = b b = a a = T1 + T2 Mod &H100000000 Next ' 更新哈希值 H0 = H0 + a Mod &H100000000 H1 = H1 + b Mod &H100000000 H2 = H2 + c Mod &H100000000 H3 = H3 + d Mod &H100000000 H4 = H4 + e Mod &H100000000 H5 = H5 + f Mod &H100000000 H6 = H6 + g Mod &H100000000 H7 = H7 + h Mod &H100000000 Next ' 将哈希值转为16进制字符串 sha256 = Hex(H0) & Hex(H1) & Hex(H2) & Hex(H3) & Hex(H4) & Hex(H5) & Hex(H6) & Hex(H7) End Function ' 定义SHA-256中使用到的辅助函数 Function Ch(x, y, z) Ch = (x And y) Xor ((Not x) And z) End Function Function Maj(x, y, z) Maj = (x And y) Xor (x And z) Xor (y And z) End Function Function Sigma0(x) Sigma0 = RotateRight(x, 2) Xor RotateRight(x, 13) Xor RotateRight(x, 22) End Function Function Sigma1(x) Sigma1 = RotateRight(x, 6) Xor RotateRight(x, 11) Xor RotateRight(x, 25) End Function Function sigma0(x) sigma0 = RotateRight(x, 7) Xor RotateRight(x, 18) Xor (x \ 3) End Function Function sigma1(x) sigma1 = RotateRight(x, 17) Xor RotateRight(x, 19) Xor (x \ 10) End Function Function RotateRight(x, n) RotateRight = (x \ 2 ^ n) Or (x * 2 ^ (32 - n)) End Function ``` 需要注意的是,此算法仅供参考,实际应用中需要根据具体情况进行调整和优化。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值